gpt4 book ai didi

ember.js - 使用 Ember 和 Ember-data : How to setup callback when a store is finished loading, 和/或关联 View 何时完成重新渲染?

转载 作者:行者123 更新时间:2023-12-04 17:38:58 26 4
gpt4 key购买 nike

我正在使用 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com