Extjs gridPanl中本地数据分页

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

解决的办法(两种):

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

Ext.ux.data.PagingStore

下载地址:http://www.sencha.com/forum/showthread.php?71532-Ext.ux.data.PagingStore-v0.5

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

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


<script type="text/javascript" src="extjs/ux/PagingStore.js"></script>
之后,我们可以使用了;



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的本地分页了,你点击下一页,和刷新,都是本地请求 ,不会远程请求了。

方法二:用到组件:PagingMemoryProxy.js

下载地址:

http://dev.sencha.com/deploy/ext-3.4.0/examples/ux/PagingMemoryProxy.js

使用,首先引入js

<script type="text/javascript" src="extjs/ux/PagingMemoryProxy.js"></script>
接着使用本地数据:

 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中分页的工具条的使用和方法一一致。




你可能感兴趣的:(ExtJs,gridPanl中本地数据分页)