响应数据格式:
easyUI在html代码中结构:
发现了什么没有,我们的表头其实是一个td在td中有一个属性field那么我们就可以获得了;
以下就是自适应代码:
- //添加事件
- function columnWidthAutoResize(){
- var cls=arguments[0];//需要自适应的列的名称
- $('#grid').datagrid({
- onLoadSuccess:function(data){
- var rows=data.rows;//得到行数据
- var columnMaxCharacter=new Array();//该列最大字符数
- //遍历所有行数据,获得该列数据的最大字符数
- for(var i=0;i<rows.length;i++){
- for(var j=0;j<cls.length;j++){//遍历需要设置的列
- var s=eval("rows["+i+"]."+cls[j]);
- //屏蔽html标签
- s=s.replace("<center>","");
- s=s.replace("</center>","");
- if((typeof columnMaxCharacter[cls[j]])=='undefined'){
- columnMaxCharacter[cls[j]]=0;
- }
- if(s.length>columnMaxCharacter[cls[j]]){
- columnMaxCharacter[cls[j]]=s.length;
- }
- }
- }
- //设置列宽度和字体
- for(var j=0;j<cls.length;j++){
- //得到该列的字体
- // alert($("td[field='"+cls[j]+"'] div").get(0).currentStyle);
- // var fontSize=$("td[field='"+cls[j]+"'] div").get(0).currentStyle.fontSize;//获得字体大小
- // fontSize= fontSize.replace("px","");//去掉px方便运算
- var fontSize=12;
- var w=fontSize*(columnMaxCharacter[cls[j]]+1);//求出宽度
- //设定该列的宽度
- $("td[field='"+cls[j]+"'] div").width(w);
- }
- }
- });
- }
下面在看如何调用:传入的参数的那一列需要自适应宽度:
- columnWidthAutoResize(new Array("orgname","showtime"));
对以上代码的解释:
- var cls=arguments[0];//需要自适应的列的名称
- var rows=data.rows;//得到行数据
- var columnMaxCharacter=new Array();//该列最大字符数
- for(var i=0;i<rows.length;i++){
- for(var j=0;j<cls.length;j++){//遍历需要设置的列
- var s=eval("rows["+i+"]."+cls[j]);
- //屏蔽html标签
- s=s.replace("<center>","");
- s=s.replace("</center>","");
- if((typeof columnMaxCharacter[cls[j]])=='undefined'){
- columnMaxCharacter[cls[j]]=0;
- }
- if(s.length>columnMaxCharacter[cls[j]]){
- columnMaxCharacter[cls[j]]=s.length;
- }
- //alert(columnMaxCharacter[cls[j]]);
- }
如果当前的s的长度比之前的该列的字符数大,那么直接设置当前字符数为最大值
- for(var j=0;j<cls.length;j++){
- var fontSize=12;
- var w=fontSize*(columnMaxCharacter[cls[j]]+1);//求出宽度
- $("td[field='"+cls[j]+"'] div").width(w);
转载注明请地址
easyUI版本:jQuery-easyui-1.2.5
如果大家发现其中不足,请指出,谢谢!
自适应之后效果图:
自适应之前效果图: