jqGrid 经常使用 总结 -2

  此次的总结是针对于一次bug,先说下咱们遇到的问题,就是后台人员告诉咱们添加数据到100条数据的时候,101条就看不到,当时我以为就是没有分页的缘由,因此我就觉得在jqgrid中设置一个loadonce就好了。这样设置以后,确实能够翻页了。可是等到翻到第二页的时候,咱们的数据有不少报错了,全是underfind,这个时候就能够看出来是formatter这个没有起做用,而后我研究了很久,确实没有找到有用的方法,(若是你们有办法的话,能够给我留言)那只能曲线救国了。jquery

  就是使用jquery的ajax请求回来数据以后,而后在设置jqgrid中的data为本地的数据,这样。请看下面的代码:ajax

1 var mydata = "";//获取到的所有的数据
2 var this_page = 1;//当前的页数
 1 function load_data_again(){ //从新加载数据
 2                 jQuery("#table_list_1").jqGrid("clearGridData");
 3                 
 4                 console.log("当前的页数:",this_page)
 5                 $.ajax({
 6                     url: "{:url('relatives_friends_list')}",
 7                     data:{
 8                         bind_type:3
 9                     },
10                     success:function(data){
11                         if(data){
12                             mydata = data;//mydata为全局变量,这个是为了赋值数据用的
13                             $("#table_list_1").jqGrid('setGridParam', {  
14                                 data:mydata,
15                                 page:this_page,//这个也是全局的变量,这个会在loadComplete以后获取到当前的页面
16                             }).trigger("reloadGrid");
17                         }
18                     }
19                 })
20             }

在程序中已经写的比较明白了,就是mydata为全局变量,为了存储获取到的数据,this_page为当前页面的页面,这个主要是为了判断当前是在哪一个页面。在下面我会jqgrid中的this

loadComplete

代码放在下面url

1 loadComplete:function(t){
2   this_page = $('#table_list_1').getGridParam('page'); // current page
3 }
相关文章
相关标签/搜索