jQuery Easyui datagrid动态列绑定

前几天有人在使用jQuery EasyUI的datagrid时,遇到不会动态绑定列的情况,而网上给出的例子可能也是比较早的处理办法,竟然需要修改easyui源码,其实解决这问题的思路是很简单,我们只需修改要显示的列即可。那位朋友最后改为这种处理时,发现还是有问题,最终我发现她返回不是合法json,里边多个方括号,这里推荐大家使用本站的JSON在线校验格式化工具来验证返回json是否正确。

这里我们以上篇文章中类似的简单json来说明这个问题,比如后台要根据当前用户的权限返回不同的json:

 

分享一个最好用的UI前端框架!

 
.代码   收藏代码
  1. public ActionResult getstudents(int level=0)  
  2. {  
  3.     List<Student> list = new List<Student>();  
  4.     list.Add(new Student() { id = 1, name = "小李" });  
  5.     list.Add(new Student() { id = 2, name = "小王" });  
  6.   
  7.     //级别是老师,则可查看学生地址  
  8.     if (level == 1)  
  9.     {  
  10.         list = new List<Student>();  
  11.         list.Add(new Student() { id = 1, name = "小李", address = "北京" });  
  12.         list.Add(new Student() { id = 2, name = "小王", address = "上海" });  
  13.     }  
  14.   
  15.     return Json(list, JsonRequestBehavior.AllowGet);  
  16. }  

 那么使用easyui datagrid时,页面上有:

.代码   收藏代码
  1. <table id="tt" style="width:700px;height:250px"></table>  

 如果你在table上使用了class="easyui-datagrid"那么你会发现ajax请求了两次,具体查看办法可看看chrome下ajax请求结果。

默认显示列调用:

.代码   收藏代码
  1. $(function () {  
  2.     $('#tt').datagrid({  
  3.         url: '/home/getstudents',  
  4.         columns: [[  
  5.             { field: 'id', title: '学生ID', width: 80 },  
  6.             { field: 'name', title: '姓名', width: 120 }  
  7.         ]]  
  8.     });  
  9. });  

 显示结果如下:

easyui动态列

那么当老师级别查看的时候,只需要修改下columns即可,后台json返回要加上address列。当然这里的权限我们作为演示是传过去的,真正项目中肯定是要在后台判断的。 分享一个最好用的UI前端框架!

.代码   收藏代码
  1. $('#tt').datagrid('options').url = '/home/getstudents?level=1';  
  2. $('#tt').datagrid({  
  3.     columns: [[  
  4.         { field: 'id', title: '学生ID', width: 80 },  
  5.         { field: 'name', title: '姓名', width: 120 },  
  6.                 { field: 'address', title: '地址', width: 120 }  
  7.     ]]  
  8. });  

 结果如下:

easyui datagrid动态列绑定

到这我们本篇所提到的问题已得到解决,其实解决思路还是来自easyui的官网,但很多人都没有这个习惯,出了问题不会主动去看官网的说明。当然也有不少朋友都访问不了官网,我这几天发现google的jQuery cdn也不稳定,迫使本人开始使用新浪的jQuery cdn。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值