微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

backbone.js – 视图应该设置模型数据吗?

我只想弄清楚一个可能很简单的问题.

视图是直接设置模型数据还是仅调用更改自己数据的模型方法

解决方法

像软件开发中的其他一切一样,“它取决于”.

如果您在视图中使用表单输入,并且只需要将这些输入中的数据输入到模型中,请直接设置数据.您可以通过多种方式执行此操作,包括从输入字段中“更改”事件,如下所示:

MyView = Backbone.View.extend({
  events: {
    "change #name","setName"
  },setName: function(e){
    var val = $(e.currentTarget).val();
    this.model.set({name: val});
  }
});

另一方面,如果您开始使用业务逻辑和其他恰好在模型中设置数据的代码(但实际上只将其作为业务逻辑的一部分),那么您应该在模型上调用方法.

一个“状态机”将是你何时这样做的一个很好的例子.或者,在我写的图库中,我对选择要显示的图像有一些逻辑.如果已选择图像,请勿再次选择.我把这个逻辑放在我的图像模型的方法中:

Image = Backbone.Model.extend({
  select: function(){
    if (!this.get("selected")){
      this.set({selected: true});
    }
  }
});

如这里所示,我喜欢按照简单的规则运行,如果我在设置调用周围没有逻辑,那么我可以从任何地方直接设置它.如果有任何与模型相关的逻辑,在集合周围,那么我把它放在模型中.

无论哪种方式,当您确实想要设置数据时,您应该使用set方法.绕过它并直接通过model.attributes设置模型的属性将阻止大量的Backbone代码触发并可能导致问题.

原文地址:https://www.jb51.cc/js/153486.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐