这两天一直在搞jqGrid分页,焦头烂额,不过还是有点收获的(主要是后台分页);
 
jqGrid分页可以分为两种,远程数据(服务器数据)分页和本地数据分页,
 
 
先看远程数据分页:
 
$("#testGrid").jqGrid({
   mtype: "POST",
   datatype: "json",     //返回的是JSON格式的数据
   pager: "#userListPg", //表格分页
   rowNum: 2, // 每页多少行,用于分页
   rownumbers: true,//显示行号
   colModel  :  userCM,// 自定义
   jsonReader: {
      id : "id"  //数据唯一值,
      root: 'users',      //加载的数据
      page: 'page',       //当前页
      total: 'total',     // 很重要 定义了 后台返回的总页数名称。
      records: 'records', // 后台返回的总数据条数;     以上5个参数一定要跟后台返回的json格式数据中,名称相同
      repeatitems: false,
  },
  onPaging: function (pageBtn) {     //翻页按钮点击事件,pageBtn 与 pager(表格分页有关),为 next_ 加上分页名
      var re_page = $(this).getGridParam('page');//获取返回的当前页
      var re_rowNum = $(this).getGridParam('rowNum');//获取每页数
      if (pageBtn === "next_userListPg") {
         queryFunc(re_page, re_rowNum);
     }else if (pageBtn === "prev_userListPg") {
         queryFunc(re_page, re_rowNum);
     }else if (pageBtn === "last_userListPg") {
         queryFunc(re_total, re_rowNum);
     }else if (pageBtn === "first_userListPg") {
         queryFunc(1,  re_rowNum);
     }
  },
});
 
function queryFunc(cr_page,size) {
   //加载数据:
   $("#testGrid").jqGrid('setGridParam',{
      url: "getUsr.do",
      postData:{ page : cr_page, size : size, 'user_age' : 20}, //发送数据,查第一页,只查2条(grid rowNum),找到所有20岁的人  
  }).trigger("reloadGrid");
}
 
 
后台返回数据:
{
  page: "1",   //当前页
  total: "3"   //一共的页数
  records :"10",//总条数
  users :[
       {id:"1",user_name:"张三",age:"20",},
       {id:"2",user_name:"李四",age:"20",},
  ],
}
 
加载本地数据:
 
初始化grid:
 $("#testGrid").jqGrid({
   mtype: "POST",
   datatype: "local",     //返回的是JSON格式的数据
   pager: "#toolListPg", //表格分页
   rowNum: 2, // 每页多少行,用于分页
   rownumbers: true,//显示行号
   colModel  :  userCM,// 自定义
   onPaging: function (pageBtn) {     //翻页按钮点击事件,pageBtn 与 pager(表格分页有关),为 next_ 加上分页名
      var re_page = $(this).getGridParam('page');//获取返回的当前页
      var re_rowNum = $(this).getGridParam('rowNum');//获取每页数
      if (pageBtn === "next_userListPg") {
         queryFunc(re_page, re_rowNum);
      }else if (pageBtn === "prev_userListPg") {
         queryFunc(re_page, re_rowNum);
      }else if (pageBtn === "last_userListPg") {
          queryFunc(re_total, re_rowNum);
      }else if (pageBtn === "first_userListPg") {
         queryFunc(1,  re_rowNum);
      }
   },
});
 
 
function queryFunc(cr_page,size){
  $.aiax({
     type:"post",
     url : "getUsr.do",    
     data:{
        page: cr_page,
        size: size
        user_age :20
     },
     async:false,  //同步     
     success:function (data) {
         data = JSON.parse(data); //装换成JSON格式
         //加载数据
        $("#testGrid").jqGrid('setGridParam', {
             data :data.users,
             localReader:{
                root: function () {returndata.users},
                page: function(object){ returndata.page},
                total:function(object){ returndata.total},
                records:function(object){ returndata.records},
               repeatitems : false
             },
       }).trigger("reloadGrid");
     },
     error : function(xhr, stat, e){
        console.error(xhr);
     }
  });
}
 
本地数据:
data:{
  page: "1",   //当前页
  total: "3"   //一共的页数
  records :"10",//总条数
  users :[
       {id:"1",user_name:"张三",age:"20",},
       {id:"2",user_name:"李四",age:"20",},
  ],
}
 
 这样就能加载进去了,
 加载远程数据是异步方法,在执行过程中界面还可以操作,没有数据时没办法弹框报错
 个人更新加载本地数据,先将数据从服务器上获取再加载,加载的方法可以封装,不用每次都写

jqGrid 分页的更多相关文章

  1. JqGrid分页按钮图标不显示的bug

    开发中遇到的一个小问题,记录一下,如果有朋友也遇到了相同的问题,可以少走些弯路少花点时间. 如图: 分页插件使用了JqGrid,但是分页栏里出现了问题,上一页.下一页这些按钮的图标都显示为空,记得以前 ...

  2. jqGrid jqGrid分页参数+条件查询

    HTML <div class="row"> <div class="col-sm-20"> <form id="for ...

  3. jqgrid 分页 (基于ashx)

    1:数据库表创建并往中插入200000条数据: 复制代码 CREATE TABLE [dbo].[T_School]( [ID] [int] IDENTITY(1,1) NOT NULL, [Scho ...

  4. jqgrid 分页时,清空原表格数据加载返回的新数据

    由于,我们是动态分页,分页后的数据是在触发分页后动态加载而来.如何使jqgrid清空原数据而加载新数据? 1)调用jqgrid的 clearGridData 方法清空表格数据 2)调用jqgrid的  ...

  5. 本地数据jqGrid分页

    var mydata=''; $(function() { var str = ''; str += "<span>共<span id='p_total'></ ...

  6. Jqgrid的用法总结与分页功能的拓展

    这是本人写的第一个与技术相关的博客,但是非挑战技术的,而是对工作的总结,另外加一点点拓展. Jqgrid的功能十分强大,强大到可以做到与数据grid相关的任何功能,同时由于在用的过程中总是不能够一气呵 ...

  7. 利用JqGrid结合ashx及EF分页显示列表之二

    上一篇文章简单利用JqGrid及ashx进行一个数据列表的显示,要文的重点是利用EF的分页与JqGrid进行结合,EF本文只是简单运用所以没有很规范,重点还是JqGrid分页的实现;本实例把JqGri ...

  8. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(8)-MVC与EasyUI DataGrid 分页

    系列目录 前言 为了符合后面更新后的重构系统,文章于2016-11-1日重写 EasyUI Datagrid在加载的时候会提交一些分页的信息到后台,我们需要根据这些信息来进行数据分页再次返回到前台 实 ...

  9. jqgrid

    官方主页 http://www.jqgrid.com/目前最新版本:jqGrid 3.7 Beta在线文档: http://www.secondpersonplural.ca/jqgriddocs/i ...

随机推荐

  1. maven项目ssh框架的整合

    1.环境 eclipse版本:Eclipse Mars2 4.5jdk版本:1.8maven版本:apache-maven 3.3.9zhnegs这是主要的开发工具版本,ssh的各种jar包版本就不列 ...

  2. 常用的自动化测试框架及测试框架的发展(Alpha)

    前言:自动化测试在过去的20年已经有了很大的发展.最初的测试工具只提供了简单的捕捉/回访功能,维护性较差.而且脚本工具实现需要很强的开发技术和经验,而且数量众多的测试脚本加上没有文档记录因此维护起来较 ...

  3. 运行第一个MapReduce程序,WordCount

    1.安装Eclipse 安装后如果无法启动重新配置Java路径(如果之前配置了Java) 2.下载安装eclipse的hadoop插件 注意版本对应,放到/uer/lib/eclipse/plugin ...

  4. 下面有关css选择器的说法错误的是?

    下面有关css选择器的说法错误的是? .intro --- 选择 class="intro" 的所有元素. #firstname --- 选择 id="firstname ...

  5. Java学习---异常处理的学习

    基础知识 任何一门计算机程序设计语言都包括有绝对正确和相对正确的语句.绝对正确: 指任何情况下, 程序都会按照流程正确执行:相对正确: 程序的运行受到运行环境的制约, 在这种情况下, 需要附加检测和控 ...

  6. Spring学习---Spring中利用组件实现从FTP服务器上传/下载文件

    FtpUtil.java import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundExcepti ...

  7. 沉淀再出发:关于IntelliJ IDEA使用的一些总结

    沉淀再出发:关于IntelliJ IDEA使用的一些总结 一.前言 在使用IDEA的时候我们会发现,如果我们先写了一个类的名字,而没有导入这个类的出处,就会提示出错,但是不能自动加入,非常的苦恼,并且 ...

  8. 沉淀,再出发:sublime中快捷键和html标签的使用和生成以及使用markdown

    沉淀,再出发:sublime中快捷键和html标签的使用和生成以及使用markdown 一.前言 工欲善其事,必先利其器.在软件代码的编写中,一定要知道IDE或者编辑器的快捷键的使用,这样可以提高很多 ...

  9. mysql_fetch_row,mysql_fetch_array,mysql_fetch_object,mysql_fetch_assoc

    php从mysql中访问数据库并取得数据,取得结果的过程中用到好几个类似的方法,区别及用法值得区分一下,看下面的代码 代码如下: <?php $link=mysql_connect('local ...

  10. 当有多个相同的DIV时,我怎么判断我点击的是哪个嘞

    链接:https://segmentfault.com/a/1190000003480973?utm_source=tuicool&utm_medium=referral 序言 这是我曾经面试 ...