Ext.PagingToolbar,Ext.data.Store,Ext.data.HttpProxy,Ext.data.JsonReader,Ext.grid.GridPanel

在这里讲一下ExtJs下的一套分页步骤以及涉及到的Ext控件.

因为引入了Json作为数据传输格式,所以这里需要通过Http获得我们想要的数据:

 proxy: new Ext.data.HttpProxy
                (
                    {
                        //url:'/Ajax/getEmpList.ashx'  
                        url: '/FX_LOG_QZ_T/getList'
                    }
                ),

Note:创建HttpProxy的同时,用url这个参数指定获取数据的路径.

竟然传输的数据是Json,顺理成章的就应该换成能解析Json的Reader:

                //解析Json
                reader: new Ext.data.JsonReader
                (
                    {
                        totalProperty: 'totalProperty',
                        root: 'data',
                        //主键
                        id: 'JSON_pid',
                        //表格显示字段列
                        fields:
                        [
                            'JSON_pid', 'JSON_no_ick', 'JSON_no_machine'
                        ]
                    }
                ),

那么一个完整的Ext.data.Store如下:

var storeMain = new Ext.data.Store
        (
            {
                //表示从哪里获得数据
                proxy: new Ext.data.HttpProxy
                (
                    {
                        //url:'/Ajax/getEmpList.ashx'  
                        url: '/FX_LOG_QZ_T/getList'
                    }
                ),

                //解析Json
                reader: new Ext.data.JsonReader
                (
                    {
                        totalProperty: 'totalProperty',
                        root: 'data',
                        //主键
                        id: 'JSON_pid',
                        //表格显示字段列
                        fields:
                        [
                            'JSON_pid', 'JSON_no_ick', 'JSON_no_machine'
                        ]
                    }
                ),
                remoteSort: true
            }
        );

Note:remoteSort指示远程排序(后台排序)

准备好数据源之后,接下来写我们的Ext分页工具条:

   var pageSize = 20;
        var pagingToolbar = new Ext.PagingToolbar
        ({
            emptyMsg: "没有数据",
            displayInfo: true,
            displayMsg: "显示从{0}条数据到{1}条数据,共{2}条数据",
            store: storeMain,
            pageSize: pageSize
        });

Note:如果配置了分页工具条,store.load()就必须在构造Grid之后执行,否则分页工具条将不起作用

 

完整的Ext.grid.GridPanel如下:

grid = new Ext.grid.GridPanel
                (
                    {
                        renderTo: 'grid',
                        height: 680,
                        width: 1240,
                        cm: colModel, //行列
                        store: storeMain, //数据源
                        trackMouseOver: true, //鼠标特效
                        loadMask: true,
                        autoShow: true,
                        autoScroll: true,
                        bbar: pagingToolbar,
                    }
                )
                

最后,在初始化时通过传参数去获取希望得到的分页数据:

                //加载数据
                storeMain.load({ params: { start: 0, limit: pageSize } });

查询参数

一般我们查询出一个具有分页功能的表格数据之后,还会需要根据用户的输入根据这个条件进行条件查询,那么用Ext可以这么实现:

首先在Ext.grid.GridPanel加入一个顶部的工具条:

                        //头部
                        tbar:
                        [
                             '姓名',
                             { xtype: 'textfield', width: 120, id: 'username', name: 'username' }
                             { text: '搜索', iconCls: 'search', handler: SerachGrid }, { xtype: 'tbseparator' }
                        ]
SerachGrid函数中重新加载数据,并且将参数加到params中
 function SerachGrid() {
            username = Ext.get('username').dom.value;
            storeMain.reload
            (
                {
                    params: { start: 0, limit: pageSize, username: username }
                }
            )
        }

 

Ext.PagingToolbar翻页时查询参数丢失的处理  

在测试数据足够分两页的情况下,我们会发现,上面的代码中存在一个问题,就是带条件查询的情况下,我们并不能如意得到翻页的数据,因为翻页时会发生查询参数丢失,查询

的数据不再是带条件的数据,为了处理这个问题,我们可以监听beforeload:

在Ext3中使用的方法是:
store.on('beforeload',function(){
    store.baseParams = {type:type_combo.getValue()};
});

在Ext4中,应该改成:
store.on("beforeload",function(){
    Ext.apply(store.proxy.extraParams, {type:type_combo.getValue()});
});

比如子啊Ext3中,代码如下:

  storeMain.on('beforeload', function () {
            storeMain.baseParams = { username: username };
        });

 

 

END

posted on 2015-10-20 21:21  巴夫巴夫  阅读(739)  评论(0编辑  收藏  举报