• 【转】Ext.data.Store加载及显示数据


    store创建好后,需要调用load()函数加载数据,加载成功后才能对store中的数据进行操作。load()调用的完整过程如下面的代码所示。

    store.load({

        params: {start:0,limit:20},

        callback: function(records, options, success){

            Ext.Msg.alert('info', '加载完毕');

        },

        scope: store,

        add: true

    });

    -   params是在store加载时发送的附加参数。

    -   callback是加载完毕时执行的回调函数,它包含3个参数:records参数表示获得的数据,options表示执行load()时传递的参数,success表示是否加载成功。

    -   Scope用来指定回调函数执行时的作用域。

    -   Add为true时,load()得到的数据会添加在原来的store数据的末尾,否则会先清除之前的数据,再将得到的数据添加到store中。

    一般来说,为了对store中的数据进行初始化,load()函数只需要执行一次。如果用params参数指定了需要使用的参数,以后再次执行reload()重新加载数据时,store会自动使用上次load()中包含的params参数内容。

    如果有一些需要固定传递的参数,也可以使用baseParams参数执行,它是一个JSON对象,里面的数据会作为参数发送给后台处理,如下面的代码所示。

    store.baseParams.start = 0;

    store.baseParams.limit = 20;

    为store加载数据之后,有时不需要把所有数据都显示出来,这时可以使用函数filterfilterBy对store中的数据进行过滤,只显示符合条件的部分,如下面的代码所示。

    filter( String field, String/RegExp value, [Boolean anyMatch],
    [Boolean caseSensitive] ) : void

    filter()函数的用法与之前谈到的find()相似,如下面的代码所示。

    store.filter('name', 'boy');

    对应的filterBy()与findBy()类似,也可以在自定义的函数中实现各种复杂判断,如下面的代码所示。

    store.filterBy(function(record) {

        return record.get('name') == 'girl' && record.get('sex') == 1;

    });

    如果想取消过滤并显示所有数据,那么可以调用clearFilter()函数,如下面的代码所示。

    store.clearFilter();

    如果想知道store上是否设置了过滤器,可以通过isFiltered()函数进行判断。

  • 相关阅读:
    机器人对话小程序
    partial关键字的含义
    TreeView控件常用写法
    电话本管理程序(实现增删改查功能)
    三层架构
    c# RegistryKey 的相关简单操作
    VS2010程序打包操作(超详细的)
    一些中文.net讲座
    对象表单自动数据邦定
    AspNetForums 2.0中的全文检索
  • 原文地址:https://www.cnblogs.com/minideas/p/1875408.html
Copyright © 2020-2023  润新知