我有一个加载子视图的主干视图。当我加载子视图时,我想在视图获取所需数据时显示加载器,并在视图准备好渲染时隐藏加载器。
我做了这样的事情:
var appView = Backbone.View.extend({
showLoader: function() {
// Code to show loader
},
hideLoader: function() {
// Code to hide loader
},
loadSubView: function() {
this.showLoader();
var myView = new MySubView();
this.$el.html(myView.render().el);
this.hideLoader();
}
});
现在,我的子视图加载一个集合并实现如下:
var mySubView = Backbone.View.extend({
initialize: function() {
this.myCollection.fetch({
async: false
});
},
render: function() {
// Code to render
}
});
我的子视图同步加载集合,因为它是我发现知道我的视图何时“准备好”渲染的唯一方法,但我认为这不是使用 Backbone 的最佳方法。
我该怎么办?