layui怎么实现数据表格自动分配列宽
发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,这篇文章主要介绍了layui怎么实现数据表格自动分配列宽的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇layui怎么实现数据表格自动分配列宽文章都会有所收获,下面我们一起
千家信息网最后更新 2025年01月20日layui怎么实现数据表格自动分配列宽
这篇文章主要介绍了layui怎么实现数据表格自动分配列宽的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇layui怎么实现数据表格自动分配列宽文章都会有所收获,下面我们一起来看看吧。
适用场景:主要是解决窗口大小改变后表格尾列出现空白和滚动条的问题-窗口由小变大,出现表格尾列出现空白
窗口由大变小,出现横向滚动条
重新加载框架后恢复正常
使用前提:
-每一列的表头必须全部设置minWidth(依靠minWidth属性进行的判断)
-自己中间使用的
-页面只能有一个数据表格,多个数据表格的话需要自己修改代码(表格的判断,列数的获取等)
具体步骤:
-监听窗口大小改变事件
var resizeTimer; $(window).resize(function () { if (resizeTimer) { clearTimeout(resizeTimer); } resizeTimer = setTimeout(function () { resizeTimer = null; dstributionColumnWidth(); }, 200); });/*经过测试发现,当窗口大小改变之后,这个方法会调用多次所以需要使用clearTimeout方法取消由 setTimeout() 方法设置的 timeout也就是说每一次调用后200毫秒内的下一次调用都会取消上一次的调用这样可以大概率保证最终只执行一次如果还是不行就把200调大点比如500当然值越小,给人的感觉越流畅*/
获取表格的宽度、列数、求出平均列宽
// 表格宽度var tabWidth = $(".layui-table-header").width();// 列数var colNum = $("tr").eq(0).find("th").length;// 平均列宽var avgWidth = tabWidth / colNum;/*求宽度和列宽的方式比较简单,也不知道有没有通用性(水平所限),自己使用没有问题,如果大家拿不到值的话就根据自己的情况写代码拿到相应的值就行了,当然要是有更好更优雅的方法也一定要留言告诉我*/
获取每一列的data-field和data-minwidth属性的值并封装为对象,并按照data-minwidth的值由大到小排序
/** * 列对象 * @param index 所在列在当前行中的索引位置(没用上可以不要) * @param name 对应表头中设置的field * @param minWidth 对象表头中的minWidth * @param width 最终的宽度 * @constructor */ function Column(index, name, minWidth, width) { this.index = index; this.name = name; this.minWidth = minWidth; this.width = width; }// 获取参数封装对象if (cols === undefined) { cols = $("tr").eq(0).find("th").map(function (index, item) { var col = new Column(index, $(this).attr("data-field"), $(this).attr("data-minwidth")); return col; }); // 排序 cols.sort(function (a, b) { return b["minWidth"] - a["minWidth"]; }); }/** * 计算列宽 * @param columns column对象数组 * @param colNum 列数 * @param tabWidth 表格宽度 * @param avgWidth 平均宽度 */ function calculateColumnWidth(columns, colNum, tabWidth, avgWidth) { // 是否显示表格横向滚动条 showOverflowX = false; // 是否完成比较 var isComplete = false; for (var i = 0; i < columns.length; i++) { var column = columns[i]; // 如果计算出的平均列宽比最大的minWidth还要大,那么剩下的就不用比较了,直接赋值即可 if (column["minWidth"] <= avgWidth || isComplete) { column["width"] = parseInt(avgWidth); isComplete = true; } else { /* 如果minWidth > 平均列宽,那么就用表格宽度减去minWidth 然后除以列数-1,重新求平均列宽 */ column["width"] = column["minWidth"]; tabWidth -= column["minWidth"]; colNum -= 1; avgWidth = tabWidth / colNum; // 如果最后一列时,平均列宽大于最小列宽,说明当前页面的宽度足够显示表格,就可以隐藏横向滚动条,反之则需要显示滚动条 if (i == columns.length - 1) { showOverflowX = true; } } } }
设置单元格宽度、设置滚动条
// 这里是根据名称查找相应的th、td标签,可能有更好的方法,欢迎留言for (var i = 0; i < cols.length; i++) { var col = cols[i]; var width = cols[i].width; $("[data-field='" + cols[i]["name"] + "']").each(function () { // 实际修改的是th、td下的div标签 // 我使用的是动画的方式,也可以选择直接赋值 $(this).children().eq(0).animate({width: width}, 200); }) }// 根据showOverflowX的值判断是否需要显示滚动条if (showOverflowX) { $('.layui-table-body').css({"overflow-x": "auto"});} else { $('.layui-table-body').css({"overflow-x": "hidden"});}
完成!完整代码
var cols, showOverflowX; /** * 列对象 * @param index 所在列在当前行中的索引位置(没用上可以不要) * @param name 对应表头中设置的field * @param minWidth 对象表头中的minWidth * @param width 最终的宽度 * @constructor */ function Column(index, name, minWidth, width) { this.index = index; this.name = name; this.minWidth = minWidth; this.width = width; } /** * 计算列宽 * @param columns column对象数组 * @param colNum 列数 * @param tabWidth 表格宽度 * @param avgWidth 平均宽度 */ function calculateColumnWidth(columns, colNum, tabWidth, avgWidth) { showOverflowX = false; var isComplete = false; for (var i = 0; i < columns.length; i++) { var column = columns[i]; if (column["minWidth"] <= avgWidth || isComplete) { column["width"] = parseInt(avgWidth); isComplete = true; } else { column["width"] = column["minWidth"]; tabWidth -= column["minWidth"]; colNum -= 1; avgWidth = tabWidth / colNum; if (i == columns.length - 1) { showOverflowX = true; } } } } /** * 分配列宽 */ function dstributionColumnWidth() { // 表格宽度 var tabWidth = $(".layui-table-header").width(); // 列数 var colNum = $("tr").eq(0).find("th").length; // 平均列宽 var avgWidth = tabWidth / colNum; if (cols === undefined) { cols = $("tr").eq(0).find("th").map(function (index, item) { var col = new Column(index, $(this).attr("data-field"), $(this).attr("data-minwidth")); return col; }); cols.sort(function (a, b) { return b["minWidth"] - a["minWidth"]; }); } calculateColumnWidth(cols, colNum, tabWidth, avgWidth); for (var i = 0; i < cols.length; i++) { var col = cols[i]; var width = cols[i].width; $("[data-field='" + cols[i]["name"] + "']").each(function () { $(this).children().eq(0).animate({width: width}, 200); }) } if (showOverflowX) { $('.layui-table-body').css({"overflow-x": "auto"}); } else { $('.layui-table-body').css({"overflow-x": "hidden"}); } } var resizeTimer; $(window).resize(function () { if (resizeTimer) { clearTimeout(resizeTimer); } resizeTimer = setTimeout(function () { resizeTimer = null; dstributionColumnWidth(); }, 200); });
使用方法
layui.config({ // 放到这个目录里 base: '/static/js/extend/'}).extend({formSelects: 'formSelects-v4.min'}); // 这里layui.use(['table', 'element', 'layer', 'jquery', 'form', 'formSelects', 'tools', 'autoColumnWidth'], function () { var table = layui.table, element = layui.element, layer = layui.layer, $ = layui.$, form = layui.form, formSelects = layui.formSelects, tools = layui.tools, // 这里 autoColumnWidth = layui.autoColumnWidth;
然后在需要的地方直接调用
autoColumnWidth.resize();
ps:窗口大小监听代码还是要自己写的
想要数据表格加载之后就分配列宽可以写在done的回调里
done: function () { autoColumnWidth.resize();}
关于"layui怎么实现数据表格自动分配列宽"这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对"layui怎么实现数据表格自动分配列宽"知识都有一定的了解,大家如果还想学习更多知识,欢迎关注行业资讯频道。
表格
宽度
对象
数据
分配
方法
表头
代码
大小
方式
横向
知识
位置
内容
属性
所在
数组
标签
空白
篇文章
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
微信服务器无响应怎么办
gulp 代理服务器
有诚信的开源数据库
橡胶套数据库
网络安全工作方案 领导小组
北京第三方软件开发大概要多少钱
软件开发编码分工
软件开发经理年薪
为什么数据库索引要用树实现
人力资源 数据库
S扫描软件开发
当下软件开发的主流技术
财经教学软件开发
数据库原理与应用实体的英语
适合做软件开发测试的笔记本
湖南触发网络技术有限公司
扬州java软件开发创新服务
软件开发出差吗
odbc数据库工具
安全管家数据库
网警是如何监管网络安全的
安卓与服务器http通信
网络安全H5文案
景区单车软件开发
看php数据库
思科网络安全设备有哪些
数据库获取当前日期的方式
网络安全与侦查专业
oracle数据库查看监听端口
扬州java软件开发创新服务