3

我正在学习骨干网。

我想知道主干视图是否总是需要主干模型。

例如,假设我有一个包含两个子面板的面板。我的结构方式是使用主面板的父视图,然后是子面板的两个子视图......

    var OuterPanel = Backbone.View.extend({
        initialize: function() {
            this.innerPanelA = new InnerPanelA(innerPanelAModel);
            this.innerPanelB = new InnerPanelB(innerPanelBModel);
        },
    });

    var outerPanel = new OuterPanel();

父视图实际上只是一个容器。它可能有一些控件,但没有需要持久化的数据。这是正确的方法吗?或者这是不好的做法?

Thnx(提前)为您提供帮助

4

1 回答 1

5

正如Backbone.View 文档中所说

主干视图几乎比代码更约定俗成——它们不会为您确定有关您的 HTML 或 CSS 的任何内容,并且可以与任何 JavaScript 模板库一起使用。

换句话说,如果你没有模型,就不要使用模型。另一方面,我会将子模型作为选项注入到外部视图实例中,而不依赖于全局变量,如下所示:

var OuterPanel = Backbone.View.extend({
    initialize: function(options) {
        this.innerPanelA = new InnerPanelA({model: options.modelA});
        this.innerPanelB = new InnerPanelB({model: options.modelB});
    }
});

var outerPanel = new OuterPanel({
    modelA: innerPanelAModel,
    modelB: innerPanelBModel
});
于 2012-12-04T17:03:06.787 回答