Easyui DataGrid动态生成列



一、DataGrid基本定义

1、HTML Page
  1. <body>  
  2.      <table id="myList"></table>  
  3. </body>  
   <body>
        <table id="myList"></table>
   </body>

2、Js中创建DataGrid     

[javascript] view plain copy print ?
  1. $("#myList").datagrid({  
  2.     title: '列表',  
  3.     url:'datagrid_data.json',  
  4.     width:500,  
  5.     remoteSort:false,  
  6.     singleSelect:true,  
  7.     fitColumns:true,  
  8.     columns:[  
  9.         [field:'testName',title:'考试名称',width:80],  
  10.         [field:'testDate',title:'考试时间',width:80],  
  11.         [field:'gradeNo',title:'年级',width:80]  
  12.     ]  
  13. });  
$("#myList").datagrid({
	title: '列表',
	url:'datagrid_data.json',
	width:500,
	remoteSort:false,
	singleSelect:true,
	fitColumns:true,
	columns:[
		[field:'testName',title:'考试名称',width:80],
		[field:'testDate',title:'考试时间',width:80],
		[field:'gradeNo',title:'年级',width:80]
	]
});

二、动态生成列

1、定义datagrid

      columns:fetchData() 

2、实现fetchData方法

[javascript] view plain copy print ?
  1. function fetchData(){  
  2.     var columns = [];  
  3.     var c = {fiele:"",title:"",width:160}  
  4.     columns.push(c);  
  5.     return [columns];  
  6. };  
function fetchData(){
	var columns = [];
	var c = {fiele:"",title:"",width:160}
	columns.push(c);
	return [columns];
};

      var c = {} 内部即为定义的列属性

3、 与后台交互的动态加载

     定义全局变量 var options = {};

     按照基本定义初始化datagrid,此时可不定义columns

     在datagrid定义外执行,fetchData()方法

[javascript] view plain copy print ?
  1. function fetchData(nj){    
  2.   var s = "";    
  3.   s = "[[";    
  4.   s = s + "{field:'testName',title:'考试名称',width:250},{field:'testDate',title:'考试时间',width:250},},";    
  5.      
  6.   // 定义可选列  
  7.   if(true){    
  8.      s = s + "{field:'gradeNo',title:'年级',width:100}";    
  9.   }  
  10.   
  11.   s = s + "]]";    
  12.   options = {};    
  13.   options.url = '......';    
  14.   options.queryParams = {    
  15.      "":""  
  16.   };    
  17.   options.columns = eval(s);    
  18.   
  19.   // 追加列  
  20.   options.columns[0].push(    
  21.      {    
  22.          title:'查看详情',width:60,    
  23.          formatter:function(value,row,index){    
  24.              return'<a href="#" οnclick="remove('+index+')">删除</a>';  
  25.          }    
  26.      }       
  27.   );    
  28.   $('#myList').datagrid(options);    
  29.   $('#myList').datagrid('reload');        
  30. }  
   function fetchData(nj){  
     var s = "";  
     s = "[[";  
     s = s + "{field:'testName',title:'考试名称',width:250},{field:'testDate',title:'考试时间',width:250},},";  
      
     // 定义可选列
     if(true){  
        s = s + "{field:'gradeNo',title:'年级',width:100}";  
     }

     s = s + "]]";  
     options = {};  
     options.url = '......';  
     options.queryParams = {  
        "":""
     };  
     options.columns = eval(s);  

     // 追加列
     options.columns[0].push(  
        {  
            title:'查看详情',width:60,  
            formatter:function(value,row,index){  
                return'<a href="#" οnclick="remove('+index+')">删除</a>';
            }  
        }     
     );  
     $('#myList').datagrid(options);  
     $('#myList').datagrid('reload');      
   }

     * js 中的eval()函数,可计算某个字符串,并执行其中的JavaScript代码 

       http://www.w3school.com.cn/jsref/jsref_eval.asp

     * 需要注意列定义的json格式



本文转载于:http://blog.csdn.net/ld_____/article/details/47615405

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值