easyUI datagrid 列宽自适应(简单 图解)(转)
响应数据格式:

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);
- }
- }
- });
- }
//添加事件
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"));
columnWidthAutoResize(new Array("orgname","showtime"));
对以上代码的解释:
- var cls=arguments[0];//需要自适应的列的名称
var cls=arguments[0];//需要自适应的列的名称
接受传入的需要自适应的列的名称数组;
- var rows=data.rows;//得到行数据
var rows=data.rows;//得到行数据
得到从服务器端响应的数据行集合
- var columnMaxCharacter=new Array();//该列最大字符数
var columnMaxCharacter=new Array();//该列最大字符数
记录需要设定列的字符最大数 (只是对中文考虑了,没有考虑英文) 最后的格式键值的形式 数组名['需要设定列名']=循环后最大字符
- for(var i=0;i<rows.length;i++){
for(var i=0;i<rows.length;i++){
遍历所有的数据行,
- for(var j=0;j<cls.length;j++){//遍历需要设置的列
for(var j=0;j<cls.length;j++){//遍历需要设置的列
- var s=eval("rows["+i+"]."+cls[j]);
var s=eval("rows["+i+"]."+cls[j]);
动态脚本 执行取出该行对应属性的字符串 rows[1].orgname 等效
- //屏蔽html标签
- s=s.replace("<center>","");
- s=s.replace("</center>","");
//屏蔽html标签
s=s.replace("<center>","");
s=s.replace("</center>","");
html标签不是显示值,所以不能当作字符算;
- if((typeof columnMaxCharacter[cls[j]])=='undefined'){
- columnMaxCharacter[cls[j]]=0;
- }
if((typeof columnMaxCharacter[cls[j]])=='undefined'){
columnMaxCharacter[cls[j]]=0;
}
如果第一次 没有给该列设置最大字符数是undefined 给默认值0 方便后面的对比
- if(s.length>columnMaxCharacter[cls[j]]){
- columnMaxCharacter[cls[j]]=s.length;
- }
- //alert(columnMaxCharacter[cls[j]]);
- }
if(s.length>columnMaxCharacter[cls[j]]){
columnMaxCharacter[cls[j]]=s.length;
}
//alert(columnMaxCharacter[cls[j]]);
}
如果当前的s的长度比之前的该列的字符数大,那么直接设置当前字符数为最大值
- for(var j=0;j<cls.length;j++){
for(var j=0;j<cls.length;j++){
这个循环遍历的是得到每一列最大字符数之后的数组,cls对应columnMaxCharacter的键值的形式
- var fontSize=12;
var fontSize=12;
这个是默认字体的大小,为什么写死值,是因为暂时没有找到在火狐下得到默认字体大小的方法 $("td[field='"+cls[j]+"'] div").get(0).currentStyle.fontSize(火狐不支持)
- var w=fontSize*(columnMaxCharacter[cls[j]]+1);//求出宽度
var w=fontSize*(columnMaxCharacter[cls[j]]+1);//求出宽度
这里是用 字体大小 * 该列最大字符数 + 1 得到列的宽度
- $("td[field='"+cls[j]+"'] div").width(w);
$("td[field='"+cls[j]+"'] div").width(w);
得到表头设置宽度,这里得到的就是表头,看上面第二张图片
转载注明请地址
easyUI版本:jQuery-easyui-1.2.5
如果大家发现其中不足,请指出,谢谢!
自适应之后效果图:

自适应之前效果图:

easyUI datagrid 列宽自适应(简单 图解)(转)的更多相关文章
- easyui datagird 列宽自适应
代码如下: onLoadSuccess: function (data) { var rows = data.rows; //得到行数据 var columnMaxCharacter = new Ar ...
- 一步步实现 easyui datagrid表格宽度自适应,效果非常好
一步步实现 easyui datagrid表格宽度自适应,效果非常好: 一.设置公共方法,使得datagrid的属性 fitColumns:true $(function(){ //初始加载,表格宽 ...
- easyui datagrid 列隐藏和显示
easyui datagrid 列隐藏和显示 用js怎么控制列的显示和隐藏? 最佳答案 $('#grid').datagrid('hideColumn','列field');把hideColu ...
- WPF DataGrid 列宽填充表格方法
WPF中使DataGrid 列宽填充表格方法,设置ColumnWidth属性为ColumnWidth="*"即可. 源码: <DataGrid AutoGenerateCol ...
- NPOI 列宽自适应 代码示例
//列宽自适应,只对英文和数字有效 for (int i = 0; i <= maxColumn; i++) { sheet.AutoSizeColumn(i); } //获取当前列的宽度,然后 ...
- js控制easyui datagrid列的显示和隐藏
easyui datagrid 列隐藏和显示 $('#grid').datagrid('hideColumn','列field'); //把hideColumn换成showColumn 即为显示列
- easyui datagrid 列的内容超出所定义的列宽时,自动换行
定义表单 nowrap="false"可以使得列中的内容超出所定义的列宽是就会自动换行pagination : true, // 当true时在DataGrid底部显示一个分页工 ...
- 动态改变EasyUI grid 列宽和隐藏列
隐藏显示 $('#yourGrid').datagrid('hideColumn','yourColumn'); $('#yourGrid').datagrid('hideColumn','yourC ...
- POI导出excel列宽自适应
让单元格宽度随着列和单元格值的宽度自适应: //存储最大列宽 Map<Integer, Integer> maxWidth = new HashMap<>(); // 将列头设 ...
随机推荐
- 如何删除 SQL Server 表中的重复行
第一种:有主键的重复行,就是说主键不重复,但是记录的内容重复比如人员表tab ,主键列id,身份证编号idcard当身份证重复的时候,保留最小id值的记录,其他删除delete a from tab ...
- html5 audio play()方法部分ios机不能播放声音
前几天遇到了一个很奇葩的问题:执行audio.play方法,浏览器.安卓.部分ios可正常播放,部分ios不能播放部分声音,这就奇怪了. 我的第一反应是: 音频文件有问题 -- 写了一个domo验证 ...
- HTTP模拟工具【C#/Winform源码】、Json绑定TreeView控件、使用了MetroModernUI、RestSharp、Dapper.Net、Newtonsoft.Json、SmartThreadPool这几个主要开源框架
HTTP模拟工具 开发语言:C#/Winform开发工具:Visual Studio 2017数据库: SQLite使用框架:界面-MetroModernUI Http请 ...
- [BZOJ2783/JLOI2012]树 树上倍增
Problem 树 题目大意 给出一棵树,求这个树上的路径的数量,要求路径上的点权和等于s且路径的上每个点深度不同. Solution 这个题目可以用不少方法做. 首先,路径上每个节点的深度不同决定了 ...
- POJ 2296 Map Labeler / ZOJ 2493 Map Labeler / HIT 2369 Map Labeler / UVAlive 2973 Map Labeler(2-sat 二分)
POJ 2296 Map Labeler / ZOJ 2493 Map Labeler / HIT 2369 Map Labeler / UVAlive 2973 Map Labeler(2-sat ...
- 深入理解javascript异步编程障眼法&&h5 web worker实现多线程
0.从一道题说起 var t = true; setTimeout(function(){ t = false; }, 1000); while(t){ } alert('end'); 1 2 3 4 ...
- 输入三个整数x、y、z,请把这三个数由小到大输出
题目:输入三个整数x,y,z,请把这三个数由小到大输出. 程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,如果x> y则将x与y的值进行交换,然后再用x与z进行比较,如果x> ...
- redhat设置开机自动连接网络
一.设置开机自动连接网络1.用root账号登录2.打开etcsysconfignetwork-scrpts目录3.vi ifcfg-eth04.将ONBOOT改为yes 二.没有图形界面如何连接网络1 ...
- Linux基础(三)
一.正文处理命令及tar命令 1.文件合并 cat a.txt b.txt > c.txt 2.打包 归档命令tar可以把多个文件打包成一个文件 如tar cvf test.tar a.txt ...
- Unity strip engine code可能会使程序崩溃
最近正在做新大厅的红包推荐口令快速领金币入口拍卖行之类的功能,同事把我的捕鱼整合到他的项目中时出现了闪退的问题,经排查是因为strip engine code选项. Strip engine code ...