博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Extjs gridPanl中本地数据分页
阅读量:6420 次
发布时间:2019-06-23

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

  hot3.png

在EXtjs的gridPanl中store数据,分页的时候,一般是请求远程后台的数据,但是现在有需求,要对前台的本地数据进行分页

解决的办法(两种):

方法一:这里我们要用到一个插件:

下载地址:

我用的是extjs3.4所以下载的是:

下载好这个外部的js之后,我们要和extjs的js一样,把它引入进来

 

之后,我们可以使用了;

 

 

var localData = [];    var AssignDisStore = new Ext.ux.data.PagingArrayStore({//本地数据分页        fields:[            {name:'id', mapping:'id'},            {name:'name', mapping:'name'}        ],        data:localData,        lastOptions:{params:{start:0, limit:10}}    });

这是本地的数据,AssignDisStore也是gridPanel中store的数据值;

bbar:new Ext.PagingToolbar({                                store:AssignDisStore,                                pageSize:pageSize,                                prependButtons:true,                                displayInfo:true,                                displayMsg:'当前显示第 {0} 到 {1}条,共 {2}条',                                emptyMsg:"没有记录信息"                            }),

这是gridPanel中分页的工具条;

这样就完成了gridPanel的本地分页了,你点击下一页,和刷新,都是本地请求 ,不会远程请求了。

方法二:用到组件:

下载地址:

使用,首先引入js

 

接着使用本地数据:

 

 

var localData=[];    var AssignDisStore = new Ext.data.Store({        proxy: new Ext.ux.data.PagingMemoryProxy(localData),        remoteSort:true,        reader: new Ext.data.ArrayReader({}, [            {name:'id'},            {name:'name'}        ])    });

其中,localData数据,我们通过ajax赋值给本地:

 

 

afterrender:function () {                    Ext.Ajax.request({                        url:'distributorAssign/getDistributor.json',                        params:{                            id:id                        },                        success:function (response) {                            var data = Ext.decode(response.responseText).distributor;                            var distributorFieldSet = relateDistributorWin.get(0).get(1);                            localData = [];//先清空数据                            for (var i = 0, v; v = data[i]; i++) {                                distributorIds.push(v.id);                                localData.push([v.id,v.companyName]);                            }                            AssignDisStore.proxy = new Ext.data.PagingMemoryProxy(localData);//PagingMemoryProxy()一次性读取数据                            AssignDisStore.load({params:{start:0, limit:10}});                            distributorFieldSet.doLayout();                        }                    });

gridPanel中分页的工具条的使用和方法一一致。

 

 

后续有很多开发填坑的文章发布,如果对你有帮助,请支持和加关注一下

https://shop119727980.taobao.com/?spm=0.0.0.0 

 

转载于:https://my.oschina.net/baishi/blog/161363

你可能感兴趣的文章
TiDB 在 G7 的实践和未来
查看>>
重新认识javascript对象(三)——原型及原型链
查看>>
小学生学“数学”
查看>>
【Vue】组件使用之参数校验
查看>>
FastDFS蛋疼的集群和负载均衡(十七)之解决LVS+Keepalived遇到的问题
查看>>
深入剖析Redis系列(二) - Redis哨兵模式与高可用集群
查看>>
Android 用于校验集合参数的小封装
查看>>
iOS混合开发库(GICXMLLayout)七、JavaScript篇
查看>>
instrument 调试 无法指出问题代码 解决
查看>>
理解缓存
查看>>
im也去中心化?Startalk(星语)的去中心化设计之路
查看>>
BAT 经典算法笔试题 —— 磁盘多路归并排序
查看>>
一次完整的HTTP请求
查看>>
Nginx限制带宽
查看>>
All Web Application Attack Techniques
查看>>
归档日志ORA-19809: 超出了恢复文件数的限制
查看>>
精品德国软件 UltraShredder 文件粉碎机
查看>>
PANDAS 数据合并与重塑(join/merge篇)
查看>>
文件时间信息在测试中的应用
查看>>
Exception loading sessions from persistent storage (tomcat异常)
查看>>