博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
EXTJS GRID分页时序号自增的实现
阅读量:5808 次
发布时间:2019-06-18

本文共 1673 字,大约阅读时间需要 5 分钟。

ExtJs Grid分页时,默认情况下每页的序号都是从1起始的,这往往不符合我们的习惯。这里实现了序号的自动增加。

先看效果图:
实现步骤如下:
1、定义全局变量。
    var record_start = 0;
2、Grid的columns部分的定义。

 columns : [ new  Ext.grid.RowNumberer({
  header :  " 序号 " ,
  width :  40 ,
  renderer: function (value,metadata,record,rowIndex){
    return  record_start  +   1   +  rowIndex;
  }
 }), {
  header :  " 项目编号 " ,
  width :  50 ,
  sortable :  false ,
  dataIndex :  " projectNumber "
 }, {
  header :  " 项目名称 " ,
  sortable :  false ,
  dataIndex :  " psName "
 }, {
  header :  " 基站名 " ,
  sortable :  false ,
  dataIndex :  " psSiteName "
 }]

3、Grid 的PagingToolbar部分的定义。

 bbar :  new  Ext.PagingToolbar({
  store : grid_store,
  pageSize :  8 ,
  displayInfo :  true ,
  beforePageText: " 第 " ,
  afterPageText: " / {0}页 " ,
  firstText: " 首页 " ,
  prevText: " 上一页 " ,
  nextText: " 下一页 " ,
  lastText: " 尾页 " ,
  refreshText: " 刷新 " ,
  displayMsg :  " 当前显示记录从 {0} - {1} 总 {2} 条记录 " ,
  emptyMsg :  " 没有相关记录! " ,
  doLoad :  function (start){
   record_start  =  start;
           var  o  =  {}, pn  =   this .paramNames;
          o[pn.start]  =  start;
          o[pn.limit]  =   this .pageSize;
           this .store.load({params:o});
     }
 })

说明:
1、全局变量record_start用于记录列表开始的数据点,如第一页,那么为0,如第二页,那么为8,这里分页pagesize设置为了8
2、分页中doLoad这部分的代码来自于Ext.PagingToolbar的doLoad方法,PagingToolbar在分页发生变化时会调用这个方法来重新load数据,只是多了个对全局变量进行赋值的步骤,为的就是在分页发生变化时,记录传递给Url的参数start的值。
3、在columns中实例化Ext.grid.RowNumberer时,重写了renderer方法,其实之所以这样做的原因,大家看一下Ext.grid.RowNumberer源码中的renderer方法就知道了,就是根据行号+1来设置序号的,这里我们改这个方法,是为了得到 行号+分页变化时得到的start参数的值+1 的值,这样就能够正确得到序号结合分页的数据了。
注意:
以上代码使用的是Ext2.x版本,如果你使用的是Ext3.x需要做以下的修改:
doLoad方法中把this.paramNames改为this.getParams()

  doLoad :  function (start){
   record_start  =  start;
           var  o  =  {}, pn  =   this .getParams();
          o[pn.start]  =  start;
          o[pn.limit]  =   this .pageSize;
           this .store.load({params:o});
     }

转载地址:http://vcubx.baihongyu.com/

你可能感兴趣的文章
JEPLUS表格组件数据平铺——JEPLUS软件快速开发平台
查看>>
CompeletableFuture的使用
查看>>
阿里云互动课堂解决方案助力淘宝教育,打造普惠教育平台
查看>>
阿里云总监课第四期,时髦的云原生应用怎么写?
查看>>
canvas 添加图片
查看>>
百度再出Lens黑科技!用Paddle Mobile实现类人眼视觉AI能力
查看>>
CentOS 挂载NTFS格式的U盘报 unknown filesystem type ‘ntfs’
查看>>
0001-CDH网络要求(Lenovo参考架构)
查看>>
用C++的源码一键获取密码,超完整的hack教学!
查看>>
Java 字节码结构剖析一 : 常量池
查看>>
Spring Cloud Finchley.SR1 的学习与应用 7 - 服务容错保护 Hystrix
查看>>
我的友情链接
查看>>
#legoo内核# 准则三:舍弃高效而采取可配置性
查看>>
druid 数据库密码加密
查看>>
monit 源码之配置文件解析
查看>>
【IPC通信】Posix消息队列使用异步事件通知
查看>>
Java 中${key}获取应用配置信息
查看>>
知我所知-个人知识管理
查看>>
centos 6.3 禁用selinux、ipv6 的无奈
查看>>
flannel 的连通与隔离 - 每天5分钟玩转 Docker 容器技术(61)
查看>>