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

本文共 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://kzlvi.baihongyu.com/

你可能感兴趣的文章
第三方开源库:imageLoader的使用
查看>>
自定义控件:飞入飞出的效果
查看>>
自定义控件:动态获取控件的高
查看>>
第三方开源库:nineoldandroid:ValueAnimator 动态设置textview的高
查看>>
第三方SDK:百度地图SDK的使用
查看>>
Android studio_迁移Eclipse项目到Android studio
查看>>
JavaScript setTimeout() clearTimeout() 方法
查看>>
CSS border 属性及用border画各种图形
查看>>
转载知乎-前端汇总资源
查看>>
JavaScript substr() 方法
查看>>
JavaScript slice() 方法
查看>>
JavaScript substring() 方法
查看>>
HTML 5 新的表单元素 datalist keygen output
查看>>
(转载)正确理解cookie和session机制原理
查看>>
jQuery ajax - ajax() 方法
查看>>
将有序数组转换为平衡二叉搜索树
查看>>
最长递增子序列
查看>>
从一列数中筛除尽可能少的数,使得从左往右看这些数是从小到大再从大到小...
查看>>
判断一个整数是否是回文数
查看>>
经典shell面试题整理
查看>>