我正在使用 Ember 和 Ember-data 从 REST API 加载几百个对象,使用自定义适配器中的 findAll 调用。我有一个引用 findAll 的 ArrayController.content,然后使用 recently added Ember.Select在选择的小部件/下拉菜单中显示对象。一旦使用所有对象(每个对象都是选择的一个选项)完全呈现,我需要在选择小部件上运行一个函数 - 特别是 Chosen.js library .
因为处理选择中的几百个对象需要一点时间(2-4 秒),所以在事件 Ember.Select.didInsertElement 和 Ember.ArrayController.contentDidChange 上使用回调不太有效;他们都过早地开火。那么是否有另一个事件或另一种方法可以替代?
最佳答案
DS.RESTAdapter.findQuery
就是答案!对比DS.RESTAdapter.findAll
方法,它创建并返回 DS.AdapterPopulatedModelArray
,它有自己的 isLoaded 正确,你可以在你的应用程序的任何地方观察!
例如:
App.store = DS.Store.create({
adapter: DS.RESTAdapter.create()
});
App.set('MyItemList', App.store.findQuery(App.Item, 'homepageList'));
App.MyView = Ember.View.extend({
refresh: function () {
console.log('finished loading custom list');
}.observes('App.MyItemList.isLoaded')
});
关于ember.js - 使用 Ember 和 Ember-data : How to setup callback when a store is finished loading, 和/或关联 View 何时完成重新渲染?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8992984/