通常情况下页面数据的分页显示分成真假两种。真分页是依靠后台查询时控制调出数据的数量来实现分页,也就是说页面在后台对数据进行处理,仅传输当前需要页的数据到前台来显示。而假分页则是后台一次性将所有的数据一起传送到前台,再由前端程序来控制数据的显示与遮蔽。

既然要分页,那么首先就必须要获得所有的数据,并且知道数据的数量。这步可以是由后台程序返回告知,当然也可以有javascript自己去读取。

datagrid分页 有一个附加的分页控件,只需后台获取分页控件自动提交的两个参数rows每页显示的记录数和page;//当前第几页,然后读取相应页数的记录,和总记录数total一块返回即可,页面如上图所示。

核心代码

要想实现分页其pagination属性必须为true:

//设置分页控件,设置其各个属性值与是否要允许列排序等

  1. <span style="font-family:SimSun;font-size:18px;"><table id="tt" " title="设置打分规则" class="easyui-datagrid" style="width: auto;
  2. height: 400px;" idfield="itemid" pagination="true" iconcls="                                                                icon-save" remoteSort="false"
  3. data-options="rownumbers:true,
  4. url:'JSONData.ashx/ProcessRequest',pageSize:5,pageList:[5,10,15,20],
  5. method:'get',toolbar:'#tb' ," fitcolumns="true" striped="true"></span>

一般处理程序中获取前台传过来的pageRows,page,

  1. <span style="font-family:SimSun;font-size:18px;"> //================================================================
  2. //获取分页和排序信息:页大小,页码,排序方式,排序字段
  3. int pageRows, page;
  4. pageRows = 10;
  5. page = 1;
  6. string order, sort, oderby; order = sort = oderby = "";
  7. if (null != context.Request.QueryString["rows"])
  8. {//获取前台传过来的每页显示数据的条数
  9. pageRows = int.Parse(context.Request.QueryString["rows"].ToString().Trim());
  10. }
  11. if (null != context.Request.QueryString["page"])
  12. {
  13. //获取当前的页码
  14. page = int.Parse(context.Request.QueryString["page"].ToString().Trim());
  15. }
  16. if (null != context.Request.QueryString["sort"])
  17. {//排序方式
  18. order = context.Request.QueryString["sort"].ToString().Trim();
  19. }
  20. if (null != context.Request.QueryString["order"])
  21. {
  22. //根据的字段
  23. sort = context.Request.QueryString["order"].ToString().Trim();
  24. }
  25. </span>

调出分页查询数据B层的方法

  1. <span style="font-family:SimSun;font-size:18px;">//调用分页的GetList方法
  2. DataSet ds = scorebll.GetListByPage(strWhere.ToString(), oderby, (page - 1) * pageRows + 1, page * pageRows);
  3. int count = scorebll.GetRecordCount(strWhere.ToString());//获取条数
  4. string strJson = ToJson.Dataset2Json(ds, count);//DataSet数据转化为Json数据
  5. context.Response.Write(strJson);//返回给前台页面
  6. context.Response.End();</span>

D层中的方法:

根据查询条件,是否排序(以哪一列排序),调用数据库中查询符合条件的数据

  1. <span style="font-family:SimSun;font-size:18px;">/// <summary>
  2. /// 分页获取数据列表
  3. /// </summary>
  4. public DataSet GetListByPage(string strWhere, string orderby, int startIndex, int endIndex)
  5. {
  6. StringBuilder strSql=new StringBuilder();
  7. strSql.Append("SELECT * FROM ( ");
  8. strSql.Append(" SELECT ROW_NUMBER() OVER (");
  9. if (!string.IsNullOrEmpty(orderby.Trim()))
  10. {
  11. strSql.Append("order by T." + orderby );
  12. }
  13. else
  14. {
  15. strSql.Append("order by T.ScoreStyleID desc");
  16. }
  17. strSql.Append(")AS Row, T.*  from t_scoreRule T ");
  18. if (!string.IsNullOrEmpty(strWhere.Trim()))
  19. {
  20. strSql.Append(" WHERE " + strWhere);
  21. }
  22. strSql.Append(" ) TT");
  23. strSql.AppendFormat(" WHERE TT.Row between {0} and {1}", startIndex, endIndex);
  24. return DbHelperSQL.Query(strSql.ToString());
  25. }</span>

在实现的过程中,我们要记得前台加上这句话

  1. <span style="font-family:SimSun;font-size:18px;"> </span>
  1. <span style="font-family:SimSun;font-size:18px;">//增加查询参数,重新加载表格
  2. function reloadgrid() {
  3. //查询参数直接添加在queryParams中
  4. var queryParams = $('#tt').datagrid('options').queryParams;
  5. getQueryParams(queryParams);
  6. $('#tt').datagrid('options').queryParams = queryParams;//传递值
  7. $("#tt").datagrid('reload');//重新加载table
  8. }</span>

表格重新加载,因为这样才能拿到后面传来的数据,如果不加这个效果没出来(付出了时间的代价)。

总结:

对于这样的框架还有很多值得我们学习的地方,上面的这些按纽都可以灵活的去添加,例如:添加导入、导出数据等,都容易实现,好的框架的学习,让我们学会了如何站在举人的肩膀上更快成长,具体的行动需要我们融入自己的学习当中,在实践中不断的体会到了,学与会用真的是两回事啊,大家共同努力多动手多实践。

jquery easyui datagrid 分页实现的更多相关文章

  1. jquery easyui datagrid 分页详解

    由于项目原因,用了jquery easyui 感觉界面不错,皮肤样式少点,可是官网最近打不开了,资料比较少,给的demo没有想要的效果,今天在用datagrid 做分页显示的时候,折腾了半天,网上的资 ...

  2. jquery easyui datagrid 分页 详解

    前些天用jquery easyui的table easyui-datagrid做分页显示的时候,折腾了很久,后来终于解决了.其实不难,最主要我不是很熟悉前端的东西. table easyui-data ...

  3. jquery easyui datagrid 分页 详解(java)

    1.首先引入easyui包,可以在官方网站下载,http://www.jeasyui.com/download/index.php <link rel="stylesheet" ...

  4. jquery easyui datagrid 分页实现---善良公社项目

    接着上篇文章,接下来给大家分享分页的实现,分页其实多多少少见过很有几种,框架中带的图片都特别的好看,会给用户以好的使用效果,具体实现,需要自己来补充代码: 图示1: 通常情况下页面数据的分页显示分成真 ...

  5. JQuery easyui Datagrid 分页事件

    easyui是Jquery中的一个轻量级UI插件,提供了一些诸如window.datagrid.button等控件.现在主要说说Datagrid中分页控件的使用. easyui中可以单独添加分页pag ...

  6. jQuery EasyUI datagrid实现本地分页的方法

    http://www.codeweblog.com/jquery-easyui-datagrid%e5%ae%9e%e7%8e%b0%e6%9c%ac%e5%9c%b0%e5%88%86%e9%a1% ...

  7. jquery easyui datagrid使用参考

    jquery easyui datagrid使用参考   创建datagrid 在页面上添加一个div或table标签,然后用jquery获取这个标签,并初始化一个datagrid.代码如下: 页面上 ...

  8. 扩展jquery easyui datagrid编辑单元格

    扩展jquery easyui datagrid编辑单元格 1.随便聊聊 这段时间由于工作上的业务需求,对jquery easyui比较感兴趣,根据比较浅薄的js知识,对jquery easyui中的 ...

  9. EasyUI Datagrid 分页显示(客户端)

    转自:https://blog.csdn.net/metal1/article/details/17536185 EasyUI Datagrid 分页显示(客户端) By ZYZ 在使用JQuery ...

随机推荐

  1. 开源 java CMS - FreeCMS2.2 单位管理

    项目地址:http://www.freeteam.cn/ 单位管理 FreeCMS支持多单位同一时候使用,并支持无限树级管理. 1. 加入根单位 从左側管理菜单点击单位管理进入. 点击"加入 ...

  2. MyEclipse中常用的快捷键大全

    http://www.cnblogs.com/wl0000-03/p/5953989.htmlMyEclipse中常用的快捷键大全 复制当前行到下(上)一行中:ctrl+alt+上下键 自动补全alt ...

  3. linux ssh_config和sshd_config配置文件

    在远程管理linux系统基本上都要使用到ssh,原因很简单:telnet.FTP等传输方式是‍以明文传送用户认证信息,本质上是不安全的,存在被网络窃听的危险.SSH(Secure Shell)目前较可 ...

  4. 远程调试Hadoop

    远程调试对应用程序开发十分有用,那如何调试Hadoop源码?这里介绍如何用IDE远程调试Hadoop源码.本文以IntelliJ IDEA作为IDE,以调试Jobhistory WEB UI代码为例进 ...

  5. openvpn证书吊销

    声明变量source ./vars使用revoke-full命令吊销客户端证书./revoke-full client-name(common name)命令执行后,我们能在keys目录中找到一个文件 ...

  6. Javascript玩转继承(三)

    在前两篇文章中,介绍了构造继承和原型继承.今天把剩下的两种写完,这两种的应用相对于前两种来说应用很少,因此称为是非主流继承方式. 首先,来看非主流继承一:实例继承法.我也不说那么多废话了,既然是非主流 ...

  7. VS自定义代码段简单使用

    在下面目录找到许多自带的代码段文件: vs安装目录\VC#\Snippets\2052\Visual C# 随便复制一个作为模板,开始改 注意这一行是最终输入的代码段:<Code Languag ...

  8. 使用PM2管理Node.js集群

    介绍 众所周知,Node.js运行在Chrome的JavaScript运行时平台上,我们把该平台优雅地称之为V8引擎.不论是V8引擎,还是之后的Node.js,都是以单线程的方式运行的,因此,在多核心 ...

  9. 玩转oracle学习第七天

     1.上节回想 2.PL/SQL的进阶 3.oracle的视图 4.oracle的触发器 目标: 1.掌握PL/SQL的高级使用方法(能编写分页过程模块,下订单过程模块.. . ) 2.会处理or ...

  10. 在java代码中用xslt处理xml文件

    java处理xml文件 import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundExceptio ...