欢迎访问中国最大的EXTJS讨论社区 首页 论坛 教程

Ext教程-一起Ext

当前位置: 首页 > 教程 > Ext Data Store >

Ext.data专题四(六):Ext.data.Store加载及显示数据

时间:2009-04-13 23:00来源: 作者: 点击:
store 创建好后,需要调用 load() 函数加载数据,加载成功后才能对 store 中的数据进行操作。 load() 调用的完整过程如下面的代码所示。 store.load({ params: {start:0,limit:20}, callback: function(reco

  

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

 

store.load({

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

    callback: function(records, options, success){

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

    },

    scope: store,

    add: true

});

 

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

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

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

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

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

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

 

store.baseParams.start = 0;

store.baseParams.limit = 20;

 

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

 

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()函数进行判断。

声明:本站教程文章版权为一起Ext(http://www.17ext.com/)所有,转载请注明出处
顶一下
(1)
100%
踩一下
(0)
0%
------分隔线----------------------------
最新评论 查看所有评论
发表评论 查看所有评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
推荐内容