响应数据格式:

easyUI在html代码中结构:

发现了什么没有,我们的表头其实是一个td在td中有一个属性field那么我们就可以获得了;

以下就是自适应代码:

  1. //添加事件
  2. function columnWidthAutoResize(){
  3. var cls=arguments[0];//需要自适应的列的名称
  4. $('#grid').datagrid({
  5. onLoadSuccess:function(data){
  6. var rows=data.rows;//得到行数据
  7. var columnMaxCharacter=new Array();//该列最大字符数
  8. //遍历所有行数据,获得该列数据的最大字符数
  9. for(var i=0;i<rows.length;i++){
  10. for(var j=0;j<cls.length;j++){//遍历需要设置的列
  11. var s=eval("rows["+i+"]."+cls[j]);
  12. //屏蔽html标签
  13. s=s.replace("<center>","");
  14. s=s.replace("</center>","");
  15. if((typeof columnMaxCharacter[cls[j]])=='undefined'){
  16. columnMaxCharacter[cls[j]]=0;
  17. }
  18. if(s.length>columnMaxCharacter[cls[j]]){
  19. columnMaxCharacter[cls[j]]=s.length;
  20. }
  21. }
  22. }
  23. //设置列宽度和字体
  24. for(var j=0;j<cls.length;j++){
  25. //得到该列的字体
  26. //    alert($("td[field='"+cls[j]+"'] div").get(0).currentStyle);
  27. // var fontSize=$("td[field='"+cls[j]+"'] div").get(0).currentStyle.fontSize;//获得字体大小
  28. //  fontSize= fontSize.replace("px","");//去掉px方便运算
  29. var fontSize=12;
  30. var w=fontSize*(columnMaxCharacter[cls[j]]+1);//求出宽度
  31. //设定该列的宽度
  32. $("td[field='"+cls[j]+"'] div").width(w);
  33. }
  34. }
  35. });
  36. }
//添加事件
                 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);
                              }
                             
                          }
                      });
                 }

下面在看如何调用:传入的参数的那一列需要自适应宽度:

  1. columnWidthAutoResize(new Array("orgname","showtime"));
  columnWidthAutoResize(new Array("orgname","showtime"));

对以上代码的解释:

  1. var cls=arguments[0];//需要自适应的列的名称
var cls=arguments[0];//需要自适应的列的名称

接受传入的需要自适应的列的名称数组;

  1. var rows=data.rows;//得到行数据
var rows=data.rows;//得到行数据

得到从服务器端响应的数据行集合

  1. var columnMaxCharacter=new Array();//该列最大字符数
var columnMaxCharacter=new Array();//该列最大字符数

记录需要设定列的字符最大数 (只是对中文考虑了,没有考虑英文) 最后的格式键值的形式   数组名['需要设定列名']=循环后最大字符

  1. for(var i=0;i<rows.length;i++){
 for(var i=0;i<rows.length;i++){

遍历所有的数据行,

  1. for(var j=0;j<cls.length;j++){//遍历需要设置的列
for(var j=0;j<cls.length;j++){//遍历需要设置的列
  1. var s=eval("rows["+i+"]."+cls[j]);
var s=eval("rows["+i+"]."+cls[j]);

动态脚本 执行取出该行对应属性的字符串  rows[1].orgname 等效

  1. //屏蔽html标签
  2. s=s.replace("<center>","");
  3. s=s.replace("</center>","");
//屏蔽html标签
s=s.replace("<center>","");
s=s.replace("</center>","");

html标签不是显示值,所以不能当作字符算;

  1. if((typeof columnMaxCharacter[cls[j]])=='undefined'){
  2. columnMaxCharacter[cls[j]]=0;
  3. }
if((typeof columnMaxCharacter[cls[j]])=='undefined'){
columnMaxCharacter[cls[j]]=0;
}

如果第一次 没有给该列设置最大字符数是undefined 给默认值0 方便后面的对比

  1. if(s.length>columnMaxCharacter[cls[j]]){
  2. columnMaxCharacter[cls[j]]=s.length;
  3. }
  4. //alert(columnMaxCharacter[cls[j]]);
  5. }
 if(s.length>columnMaxCharacter[cls[j]]){
columnMaxCharacter[cls[j]]=s.length;
}
//alert(columnMaxCharacter[cls[j]]);
}

如果当前的s的长度比之前的该列的字符数大,那么直接设置当前字符数为最大值

  1. for(var j=0;j<cls.length;j++){
 for(var j=0;j<cls.length;j++){

这个循环遍历的是得到每一列最大字符数之后的数组,cls对应columnMaxCharacter的键值的形式

  1. var fontSize=12;
 var fontSize=12;

这个是默认字体的大小,为什么写死值,是因为暂时没有找到在火狐下得到默认字体大小的方法 $("td[field='"+cls[j]+"'] div").get(0).currentStyle.fontSize(火狐不支持)

  1. var w=fontSize*(columnMaxCharacter[cls[j]]+1);//求出宽度
   var w=fontSize*(columnMaxCharacter[cls[j]]+1);//求出宽度

这里是用 字体大小 * 该列最大字符数 + 1 得到列的宽度

  1. $("td[field='"+cls[j]+"'] div").width(w);
  $("td[field='"+cls[j]+"'] div").width(w);

得到表头设置宽度,这里得到的就是表头,看上面第二张图片

转载注明请地址

easyUI版本:jQuery-easyui-1.2.5

如果大家发现其中不足,请指出,谢谢!

自适应之后效果图:

自适应之前效果图:



easyUI datagrid 列宽自适应(简单 图解)(转)的更多相关文章

  1. easyui datagird 列宽自适应

    代码如下: onLoadSuccess: function (data) { var rows = data.rows; //得到行数据 var columnMaxCharacter = new Ar ...

  2. 一步步实现 easyui datagrid表格宽度自适应,效果非常好

    一步步实现 easyui datagrid表格宽度自适应,效果非常好: 一.设置公共方法,使得datagrid的属性  fitColumns:true $(function(){ //初始加载,表格宽 ...

  3. easyui datagrid 列隐藏和显示

    easyui datagrid 列隐藏和显示 用js怎么控制列的显示和隐藏?   最佳答案   $('#grid').datagrid('hideColumn','列field');把hideColu ...

  4. WPF DataGrid 列宽填充表格方法

    WPF中使DataGrid 列宽填充表格方法,设置ColumnWidth属性为ColumnWidth="*"即可. 源码: <DataGrid AutoGenerateCol ...

  5. NPOI 列宽自适应 代码示例

    //列宽自适应,只对英文和数字有效 for (int i = 0; i <= maxColumn; i++) { sheet.AutoSizeColumn(i); } //获取当前列的宽度,然后 ...

  6. js控制easyui datagrid列的显示和隐藏

    easyui datagrid 列隐藏和显示 $('#grid').datagrid('hideColumn','列field'); //把hideColumn换成showColumn 即为显示列

  7. easyui datagrid 列的内容超出所定义的列宽时,自动换行

    定义表单  nowrap="false"可以使得列中的内容超出所定义的列宽是就会自动换行pagination : true, // 当true时在DataGrid底部显示一个分页工 ...

  8. 动态改变EasyUI grid 列宽和隐藏列

    隐藏显示 $('#yourGrid').datagrid('hideColumn','yourColumn'); $('#yourGrid').datagrid('hideColumn','yourC ...

  9. POI导出excel列宽自适应

    让单元格宽度随着列和单元格值的宽度自适应: //存储最大列宽 Map<Integer, Integer> maxWidth = new HashMap<>(); // 将列头设 ...

随机推荐

  1. 关于Lumen / Laravel .env 文件中的环境变量是如何生效的

    .env 文件包含默认环境变量,我们还可自定义其他任何有效的变量,并可通过  调用 env() 或 $_SERVER 或 $_ENV  来获取该变量.那么env()是如何加载到这些变量的呢?在Lume ...

  2. PLC编程算法

    PLC编程算法(一) 01 开关量也称逻辑量,指仅有两个取值,0或1.ON或OFF.它是最常用的控制,对它进行控制是PLC的优势,也是PLC最基本的应用. 开关量控制的目的是,根据开关量的当前输入组合 ...

  3. linux中grep命令的用法

    作为linux中最为常用的三大文本(awk,sed,grep)处理工具之一,掌握好其用法是很有必要的. 首先谈一下grep命令的常用格式为:[grep  [选项]  "模式"  [ ...

  4. hdu_3746: Cyclic Nacklace

    题目链接 给出一个字符串,你可以通过在首尾加入字符使其变成一个具有周期T(T>=2)的字符串,求所需加入的最少字符数. 所考察算法仍然是对next数组含义的理解 #include<cstd ...

  5. OI内的排列与组合(简单版)

    §1基本原理 △让我们来看下面问题: 从甲地到乙地,可以乘火车,也可以乘汽车,还可以乘轮船.一天中,火车有4班,汽车有2班,轮船有3班.那么,一天中乘坐这些交通工具从甲地到乙地共有多少种不同走法?△分 ...

  6. spring boot 配置文件application

    场景:在项目部署的过程中,对于spring boot的配置文件一直不很了解,直到项目出现一个莫名其妙的问题——工程classes中的配置文件被覆盖,程序启动总是报错! 1  配置文件的优先级 appl ...

  7. ibatis 架构

    从结构图中我们能够看出来ibatis框架中的几个关键的结构: 1.     SqlMapConfig.xml 2.     SqlMap.xml 3.     ParameterObject 4.   ...

  8. sping 框架学习之——初始篇

    sping框架学习: 1,什么是spring框架 spring是J2EE应用程序框架,是轻量级的IoC和AOP的容器框架,主要是针对javaBean的生命周期进行管理的轻量级容器,可以单独使用,也可以 ...

  9. iOS 配置

    1.git的配置 使用Github,也许大家觉得比较麻烦的就是在每次push的时候,都需要输入用户名和密码.如果使用SSH,就可以记住用户名,并创建属于自己的密码来保证安全操作,还有神奇的一招可以“不 ...

  10. Nlpir Parser智能语义分析系统文本新算法

    文本挖掘或者文档挖掘是一个从非结构化文本信息中获取用户感兴趣或者有用的模式的过程文本挖掘涵盖多种技术,包括信息抽取,信息检索,自然语言处理和数据挖掘技术.它的主要用途是从原本未经使用的文本中提取出未知 ...