我有理由在Backbone.js中避免这种情况吗?

时间:2010-12-10 18:41:57

标签: javascript backbone.js

我越来越喜欢backbone.js了。我希望为给定的模型提供多个视图:

  • 一个列表视图,其中每个模型都有一个带有自己的li元素的视图。
  • 详细视图,显示模型的所有细节。

我的问题是,我正在寻求一种方法,让一个观点与另一个观点进行沟通并选出以下内容:

/** Allow a model to keep track of it's views. **/
Backbone.Model.prototype.addView = function (view) {
    // Ensure our model has a view array.
    if (typeof this.views === 'undefined')
    {
        this.views = [];
    }

    // Append our newest view to the array only if it is not already present.
    if (_.indexOf(this.views, view) === -1)
    {
        this.views.push(view);
    }
}

/** Allow a model to remove all of it's views.
 * 
 * @param {Object} args Any arguments will be provided to the view's method.
 */
Backbone.Model.prototype.unloadViews = function (args) {
    var n = (typeof this.views === 'undefined') ? 0 : this.views.length;
    for (var i = 0; i < n; i++)
    {
        var view = this.views[i];
        if (typeof view.unloadView === 'function')
        {
           view.unloadView(args);
        }
    }
}

/** Allow a model to re-render all of it's views.
 * 
 * @param {Object} args Any argyments will be provided to the view's method.
 */
Backbone.Model.prototype.renderViews = function (args) {
   var n = (typeof this.views === 'undefined') ? 0 : this.views.length;
   for (var i = 0; i < n; i++)
   {
        var view = this.views[i];
        if (typeof view.render === 'function')
        {
            view.render(args);
        }
   }
}

我的问题

  1. 我错过了一些东西,因为我学习了backbone.js,这将允许我这样做吗?
  2. 我有理由避免这种情况吗?
  3. 其他信息

    我在GitHub上分享了这个应用程序(非常简陋):https://github.com/aarongreenlee/Learning-backbone.js。如果您希望在该环境中查看代码,可以在此处访问它:https://github.com/aarongreenlee/Learning-backbone.js/commit/ea4e61d934d2f987726720e81c479f9d9bb86e09#diff-2(初始提交)。

    感谢您的时间和帮助!

2 个答案:

答案 0 :(得分:13)

你的观点可以有一个像参考的树,但你的模型不应该知道你的观点!

您应该将视图设置为从模型中侦听更改事件并让它们做出相应的反应(重新渲染)。

通过这种方式,您可以避免软件下部(应该是坚如磐石的模型)与较高部分(视图)之间的交叉引用。经典的MVC分离。

所以移动你的addViews,removeViews到Backbone.View它应该是好的。您将创建一个分层视图系统,就像sproutcore提供的那样。

玩得开心!

答案 1 :(得分:1)

来自Document Cloud的Jeremy Ashkenas的Twitter的回答

  

@aarongreenlee没理由避免它    - 如果你想让你的观点保持彼此的树状参考,   这肯定是合法的。 - @ jashkenas