EasyUI 数据表格datagrid列自适应内容宽度(不需重新加载表格)

项目初期在加载数据表格的时候为了提高表格数据渲染速度,设置了默认宽度。
现需求需要加一个表格自适应的功能,触发改功能,改变列宽度,但是不重新渲染表格,不发生数据请求。

设计思路,遍历每项的所有数据,比较字节符串长度,取最大长度。再用最大长度和标题长度比较,如果标题长就去标题长度,如果字符串长,就取字符串的。
js

//表格自适应方法
function changeWidth(agstr){
    var dg = $('#'+agstr);
    dg.datagrid("loading");//显示加载状态$$$
    var fn=function(){
        var opts = dg.datagrid('getColumnFields');    //获取表头所有field
        var data=dg.datagrid('getData');//获取数据表格请求的数据
        var role = data.rows;//数据表格请求的数据,即每行的数据
            for (var i = 0; i ro_width){
                            ro_width = StringTolog(role[j][field]);//比较当前field列的每条数据长度,取最大值
                        }
                    }
                if(ro_width

调用以上两个方法就可以实现列宽自适应。
但是发现执行此方法之后,表头和表身的单元格宽度都已经固定写死,如果此时触发调整列宽大小事件,只能改变表头宽度,不会改变表身列宽,所以自适应列宽后可以取消改变列宽大小的功能
封装冻结列方法:

//冻结列,禁止调节列尺寸$("#id").datagrid('lockColumn',field值);
$.extend($.fn.datagrid.methods, {
    lockColumn: function(jq, field){
        return jq.each(function(){
            var p = $(this).datagrid('getPanel');    // 获取数据表格面板
            var cell = p.find('div.datagrid-header td[field=' + field + '] > div.datagrid-cell'); // 获取数据表格监听改变列宽事件的节点
            cell.resizable({disabled:true}); // 禁止改变列宽
        });
    }
});

在给每列设置宽度的时候调用该方法
dg.datagrid('lockColumn',field);
changeWidth 方法中的※※※位置

在重新定义列宽的时候如果数据量过大会导致页面卡顿,可以再触发该方法的开始位置调用datagrid的loading方法,结束时调用loaded方法,changeWidth 方法中的$$$位置
clipboard.png

因为在触发表格自适应方法后调用了datagrid的冻结列方法,所以再重新查询数据的时候表头不会重新渲染,只有表身会,,表身就会恢复默认宽度,就会出现表头和表身对不齐的问题,表头也不能改变宽度。
解决办法,在数据表格数据加载成功时取消冻结列,清空之前计算的列宽
clipboard.png
封装取消冻结列方法

//取消冻结列,允许调节列尺寸$("#id").datagrid('unlockColumn',field值);
$.extend($.fn.datagrid.methods, {
    unlockColumn: function(jq, field){
        return jq.each(function(){
            var p = $(this).datagrid('getPanel');    // 获取数据表格面板
            var cell = p.find('div.datagrid-header td[field=' + field + '] > div.datagrid-cell');  // 获取数据表格监听改变列宽事件的节点
            cell.resizable({disabled:false}); // 允许改变列宽
        });
    }
});

数据加载成功触发

onLoadSuccess: function (data) {
            var opts = $(this).datagrid('getColumnFields');    //获取表头所有field
             for(var i=0;i

EasyUI 数据表格datagrid列自适应内容宽度(不需重新加载表格)_第1张图片

你可能感兴趣的:(easyui,javascript)