View的backbone变化模型

发布于 2024-12-22 11:20:07 字数 1044 浏览 0 评论 0原文

我对 Backbone 相当陌生,有以下问题:

我有一组模型。

我有一个显示选项卡的集合视图(带有集合中每个模型的视图)。

我有一个模型的视图(内容)。

我有一个带有路由的路由器。

我想要实现的是像 http://jqueryui.com/demos/tabs/

我单击一个选项卡的 功能(集合模型)然后想要将模型传递到内容视图,可能会更改它并反映集合中的更改。

我想出了四种解决方案:

在路由器中:

'switchCommunity': function(id) {
        // (a) set new model attributes
        this.view.community.model.set(communities.get(id));

        // (b) replace model
        this.view.community.model = communities.get(id);

        // (c) a custom function of the view changes its model
        this.view.community.changeModel(communities.get(id));

        // (d) a new view
        this.view.community = new View({
            model: communities.get(id)
        })
}

这里的问题是

  • (a) 没有反映对模型的更改 集合

  • (b) 不会触发(更改)事件,因为绑定在 视图的初始化函数永远不会触发,因为它是 一个完全新的模型

  • (c) 对我来说似乎是一个黑客

  • (d) 每次我单击一个选项卡时,都会创建一个新视图(这是一个 性能问题?)

这里的最佳实践是什么?

I am fairly new to Backbone and have the following question:

I have a collection of models.

I have a collection view displaying tabs (with a view for each model in the collection).

I have a view for a model (for the content).

I have a router with routes.

What I am trying to achieve is a functionality like http://jqueryui.com/demos/tabs/

I click on a tab (model of collection) and then want to pass the model to the content view maybe change it and reflect the changes in the collection.

I came up with four solutions:

In the router:

'switchCommunity': function(id) {
        // (a) set new model attributes
        this.view.community.model.set(communities.get(id));

        // (b) replace model
        this.view.community.model = communities.get(id);

        // (c) a custom function of the view changes its model
        this.view.community.changeModel(communities.get(id));

        // (d) a new view
        this.view.community = new View({
            model: communities.get(id)
        })
}

The problem here is

  • (a) does not reflect changes to the model in the
    collection

  • (b) does not trigger (change) events, because the bind in the
    initialize function of the view never triggers, because it is
    a completly new model

  • (c) seems like a hack to me

  • (d) everytime i click on a tab a new view is created (is this a
    performance issue?)

What is the best pratice here?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

榆西 2024-12-29 11:20:07

您的解决方案之一几乎没问题:D

这就是您想要的:

this.view.community.model.set(communities.get(id).toJSON());

这也会触发 model.on("change") 。

One of your solution is close to be okay :D

Here is what you want:

this.view.community.model.set(communities.get(id).toJSON());

And this will trigger model.on("change") as well.

极致的悲 2024-12-29 11:20:07

为什么你认为(c)是一个黑客行为?这似乎是一个封装旧模型的解绑并连接新模型的好地方。

Why do you think (c) is a hack? It seems like a good place to encapsulate the unbinding of the old model, and connecting up the new one.

西瑶 2024-12-29 11:20:07

Backbone.Marionette 插件为您的问题提供了简化的解决方案。

它提供应用程序初始化、视图管理和事件聚合的功能。

从本质上讲,它消除了隐藏和显示多种视图的痛苦。

您可以阅读这篇博客文章 了解更多信息。

The Backbone.Marionette plugin provides a streamlined solution for your problem.

It provides functionality for Application Initialization, View Management, and Event Aggregation.

In essence, it takes the pain out of hiding and showing multiple views.

You can read this blog post to learn more about it.

叶落知秋 2024-12-29 11:20:07

简短的答案是你应该使用 d。是的,它的性能不高,但除非您注意到用户界面速度变慢,否则您不必太担心。您应该编写一些 1. 始终有效 2. 不需要很长时间的代码,以便您可以继续编写其他更重要的功能。

如果/当您需要更多性能时,您可以花额外的时间来执行 c。为了获得最佳性能,您不应该破坏并重新渲染模板。您应该使用 jquery 手动查找 DOM 上的元素并用新模型替换它们。当您调用时:

view.$el = _.template(string, model); 

代码很少,但浏览器需要做很多工作。用新模型替换 DOM 的性能要高得多。

如果您需要更高的性能,可以使用对象池。我一直致力于开发用于骨干网的 PerfView,它实现了很多优化。 https://github.com/puppybits/BackboneJS-PerfView 代码中有很多注释保持最佳浏览器性能的最佳实践。

The short answer is you should use d. Yes is isn't performant but unless you notice slowdown in the user interface you shouldn't worry too much. You should code something that 1. always works 2. doesn't take long to code so you can move on to coding other more important features.

If/when you need more performance then you can take the extra time to do c. To be the most performant you shouldn't destroy and re-render templates. You should use jquery to manually find the elements on the DOM and replace them with the new model. When you call:

view.$el = _.template(string, model); 

It's very little code but lots of work for the browser. Replacing the DOM with a new model is much more performant.

If you need to be more performant you can use object pooling. I've been working on a PerfView for backbone that implements a lot of optimizations. https://github.com/puppybits/BackboneJS-PerfView There's comments in the code with a lot of best practices to maintain the best browser performance.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文