extjs 获取所有店铺记录
Posted
技术标签:
【中文标题】extjs 获取所有店铺记录【英文标题】:Extjs get all store records 【发布时间】:2013-09-10 13:45:43 【问题描述】:我有一个问题。将过滤器添加到存储时,是否可以获取加载到存储中的所有记录?例如,如果我将 34 条记录加载到存储中,然后应用过滤器并且只剩下 15 条,我是否可以在不清除过滤器的情况下获得这 34 条记录?
【问题讨论】:
【参考方案1】:编辑:这最初是针对 Ext 4.2 回答的,其中 snapshot
是公开的并记录在案。如今它已经消失了。所以这里是 Ext 5 和 6 的更新。
分机 5 / 6
一个班轮:
var allRecords = (store.getData().getSource() || store.getData()).getRange();
分解:
var data = store.getData();
// get unfiltered collection (will be null if the store has never been filtered)
var snapshot = data.getSource();
// pick the one that exists
var unfilteredCollection = snapshot || data;
// get items in an array
var allRecords = unfilteredCollection.getRange();
Store#getData
为您提供商店的收藏。
Collection#getSource
为您提供商店的“来源”,即未过滤的集合——但前提是该集合已被过滤,否则返回null
。
在这两种情况下,您都会收到Ext.util.Collection
。使用getRange
获取实际的项目数组。
分机 5 getUnfiltered
方法
getUnfiltered
方法在 Ext 5 中的某个时候被引入(据我所知是 5.0.1,但 Ext 5 的文档目前处于离线状态......)。它在 Ext 5 的第一个版本中不存在,并且在 Ext 6 中消失了。所以,好吧......不要使用它!除非您想无缘无故地将代码绑定到 Ext 5,否则请使用上述方法。
分机 4
(原答案)
整个加载的数据集存储在商店的snapshot
属性中。
它只在需要时创建。这意味着在将某些过滤器应用于商店之前,该属性将不可用。因此,要以安全的方式获取您想要的信息,请使用:
var allRecords = store.snapshot || store.data;
分机 4 / 5 / 6
(可能还有未来的版本)
您可以使用query
或queryBy
。
这似乎是更向前兼容的方法,因为与以前的方法相反,此 API 没有跨版本更改。
不幸的是,这将遍历集合并产生额外的处理成本...根据您的集合的大小,这可能会或可能不会忽略不计。
var allRecords = store
.queryBy(function() return true; ) // returns a collection
.getRange(); // returns array of items
【讨论】:
我不明白为什么 Sencha 很难在商店中放置一个 getAllRecords() 方法。这似乎不直观 是的...我认为这是他们试图通过在 Ext 5 中添加连锁店来解决的问题。 我建议使用store.query()
,因为这是一个公开且有文档记录的 API,而快照不是。
@Alexander 它是......当它存在的时候。我已经更新了更新版本的答案。感谢您的通知。【参考方案2】:
要从加载的商店中获取所有未过滤的数据,您可以尝试 var records = store.getUnfiltered();
注意:我使用的是 Ext Js 5.1。不确定早期版本。
【讨论】:
getUnfiltered() 在 Ext 6.x 中不可用【参考方案3】:也许一种更向前兼容的方法(即 ExtJS 版本 >= 5)如下:
var allRecords = store.getData().getSource().getRange();
根据文档,这应该适用于 >= 5.0 的版本。
【讨论】:
在 6.0.2 中,我只使用: var recs = store.getRange();store.getRange();
仅返回过滤记录
警告:这仅在商店当前被过滤时才有效。否则,它会生成一个 TypeError。【参考方案4】:
在最新的 Extjs 6.2.0 中可以使用
var allRecs = Store.getData().getSource().items
【讨论】:
警告:如果存储被过滤,getSource() 将返回 null。不要使用这个。【参考方案5】:如果您只想从 http 响应中获取原始记录 - 这是我的解决方案:
将getRawRecords
函数添加到store
类:
Ext.override(Ext.data.Store,
getRawRecords: function()
return Ext.Array.map(this.getData().getRange(), function(record)
return record.data;
);
);
用法:
var rawData = store.getRawRecords();
【讨论】:
【参考方案6】:对于带有 JSON TreeStore 的 ExtJS 4.2.1(是的,我知道它很旧)的情况,我不得不使用:store.proxy.reader.jsonData
,因为 store.snapshot
、store.data
、store.query
或 store.queryBy
没有存在。
【讨论】:
以上是关于extjs 获取所有店铺记录的主要内容,如果未能解决你的问题,请参考以下文章
Sencha Touch List Paging: 限制店铺记录数
校园商铺-6店铺编辑列表和列表功能-6店铺列表展示之Controller层的实现
现欲设计一个电子商务网站系统,该系统需要记录如下信息,其中下划线为标识信息: •客户有客户名联系电话配送地址; •商品有商品名类别; •店铺有店铺名信誉度注册地址; •同一商品会在不