·您现在的位置: 云翼网络 >> 文章中心 >> 网站建设 >> 网站建设开发 >> ASP.NET网站开发 >> Jquery easy ui datagrid動態加載列問題

Jquery easy ui datagrid動態加載列問題

作者:佚名      ASP.NET网站开发编辑:admin      更新时间:2022-07-23

Jquery easy ui datagrid動態加載列問題

1.如下图效果是当选择不同的日期范围时datagrid则会加载出对应的列数

2.首先是后台组装数据,我采用的是循环并拼接DataTable数据,如下代码

          //循環添加datagrid所需的表頭數據                for (int i = 0; i < table.Columns.Count; i++)                {                    columns.AppendFormat("{{field:'{0}',title:'{1}',align:'center',width:{2}}},", table.Columns[i].ColumnName, table.Columns[i].ColumnName, 41);                }                //刪除最有一個filed多餘的","號                if (table.Columns.Count > 0)                {                    columns.Remove(columns.Length - 1, 1);                }                columns.Append("]]");                //組裝工令各站排程達成狀況表頭和數據                 Dictionary<string, object> objDic = new Dictionary<string, object>();                objDic.Add("columns", columns.ToString()); //datagrid表头                objDic.Add("rows", table); //datagrid表数据          //转换为Json格式                return Common.JsonHelper.ToJson(objDic)

3.取得浏览器所返回的组装后的JSON格式数据,如下

{"columns":"[[{field:'Item',title:'項目',align:'center',width:120},{field:'SumMonth',title:'3月份累計',align:'center',width:70},{field:'03/01',title:'03/01',align:'center',width:41},{field:'03/02',title:'03/02',align:'center',width:41},{field:'03/03',title:'03/03',align:'center',width:41},{field:'03/04',title:'03/04',align:'center',width:41},{field:'03/05',title:'03/05',align:'center',width:41},{field:'03/06',title:'03/06',align:'center',width:41},{field:'03/07',title:'03/07',align:'center',width:41},{field:'03/08',title:'03/08',align:'center',width:41},{field:'03/09',title:'03/09',align:'center',width:41},{field:'03/10',title:'03/10',align:'center',width:41},{field:'03/11',title:'03/11',align:'center',width:41},{field:'03/12',title:'03/12',align:'center',width:41},{field:'03/13',title:'03/13',align:'center',width:41}]]","rows":[{"SerailNum":1,"Item":"累計各LOT耗用工時之合(H)","SumMonth":142.00,"03/01":null,"03/02":null,"03/03":null,"03/04":50.00,"03/05":null,"03/06":7.00,"03/07":42.00,"03/08":null,"03/09":null,"03/10":17.00,"03/11":null,"03/12":26.00,"03/13":null},{"SerailNum":2,"Item":"產出LOT批","SumMonth":13.00,"03/01":0.00,"03/02":0.00,"03/03":0.00,"03/04":2.00,"03/05":0.00,"03/06":4.00,"03/07":2.00,"03/08":0.00,"03/09":0.00,"03/10":1.00,"03/11":0.00,"03/12":4.00,"03/13":0.00},{"SerailNum":3,"Item":"平均實際CT","SumMonth":10.92,"03/01":null,"03/02":null,"03/03":null,"03/04":25.00,"03/05":null,"03/06":1.75,"03/07":21.00,"03/08":null,"03/09":null,"03/10":17.00,"03/11":null,"03/12":6.50,"03/13":null}]}

4.浏览器端解析数据,并绑定datagrid

            //綁定工令各站排程達成狀況                    $("#dg_PDL_RealCT").datagrid({                        width: 'auto',  //寬度                        height: 'auto',  //高度                        singleSelect: true, //允許選中一行                        striped: true, //设置为true将交替显示行背景。                        rownumbers: true, //顯示行號                        title: "站別實際CT-日報", //標題                        iconCls: "icon-save", //圖表                        collapsible: true, //隱藏按鈕                        method: "post", //post請求                        showFooter: true,                        loadMsg: "數據加載中...", //載入信息時提示內容                        onLoadError: function () {                            $.messager.alert('溫馨提示', "加载数据失败!!!");                        },                        view: myview,                        emptyMsg: '沒有檢索到相關數據!'                    }); //end datagrid                    //綁定工令各站排程達成狀況表頭                    $.post("/PI/PDL_RealCT", { "BDate": $("#BDate").datebox('getValue'), "EDate": $("#EDate").datebox('getValue'), "PRocCode": $("#ProcCode").combobox('getValue') }, function (data) {                        setTimeout(function () {                //将json格式数据转换为js对象                            var json = eval("(" + data + ")");                //获取datagrid熟悉对象 并为其赋值                            var opt = $("#dg_PDL_RealCT").datagrid('options');                //为datagrid表头赋值                            opt.columns = eval(json.columns);                            $("#dg_PDL_RealCT").datagrid(opt);                //加载datagrid内容                            $("#dg_PDL_RealCT").datagrid("loadData", json.rows);                            $.messager.progress('close');                        }, 1000); //end setTimeout                    }); //end postgh