ExtJs Grid分页时序号自增的实现

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});
     }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值