详情:ember-data-1.0.0.beta.3和默认的RESTAdapter
我可能误解了store.find()
方法是如何工作的,但是,根据我的理解,如果我要求的记录已存在于商店中,则以下代码不应查询服务器:
var IndexRoute = Em.Route.extend({
model: function() {
return this.store.find('link');
},
});
来自DS.Store.find()
的emberjs.com文档:
find方法将始终返回将使用记录解析的promise。如果记录已经在商店中,则承诺将立即得到解决。否则,商店将询问适配器的find方法以找到必要的数据。
我有另一条路径使用完全相同的模型钩子,但是当我访问该路径时,即使数据已经存储在商店中,服务器也会被查询。如果我回到Index路线,它会再次被查询。 .find()
不应该处理这个问题吗?
答案 0 :(得分:17)
find方法将始终返回将要解析的promise 与记录。如果记录已经在商店,那么承诺 将立即解决。否则,商店会问 adapter的find方法来查找必要的数据。
通过ID this.store.find('link', 1)
查找时,这只是工作。使用this.store.find('link')
将始终在服务器中执行请求。
您可以使用all
方法this.store.all('link')
获取本地数据。但是,在您的应用的某个位置,您需要使用find
方法预加载该数据。否则all
将不返回任何内容。
您可以使用以下方法获得所需的行为:
App.ApplicationRoute = Ember.Route.extend({
model: function() {
// preload all data from the server once
this.store.find('person');
}
});
App.LinksRoute = Ember.Route.extend({
model: function() {
// get the local data without request the server
return this.store.all('person');
}
});
App.OtherRoute = Ember.Route.extend({
model: function() {
// get the local data without request the server
return this.store.all('person');
}
});
我做了一个小提琴,请看看http://jsfiddle.net/marciojunior/Az2Uc/
那个小提琴使用jquery mockjax,如果你看到浏览器控制台MOCK GET: /people
只显示一次,这就像一个常规的xhr请求,但是它被嘲笑了。转换到people1
和people2
将不会执行其他请求只获取本地数据。