javascript - 在 Backbone 中使用 model.set 更改嵌套属性

标签 javascript json backbone.js marionette backbone-model

我正在尝试做我希望做的一件简单的事情——只在对象的子属性上做一个 model.set。

现在,我有一个看起来像这样的模型:

{
            "attr1" : true,
            "attr2" : this.model.get("username"),
            "attr3" : $('#tenant_select').val(),
            "attr_array": [
                {
                    "id": "sub_1",
                    "state": "active"
                },
                {
                    "id": "sub_22",
                    "state": "not_active"
                }
            ]
        }

我希望能够访问 myMode.attr_array.state 并更改值。但是,使用 .set 我只能更改第一级的属性,即 attr_array。

有没有办法使用 model.set 来做到这一点?

最佳答案

你可以做到(我想知道你为什么没能做到)。但是你必须要小心:

var array = this.get('attr_array');
array[1].state = 'active';
this.set('attr_array', array);

这里有什么问题?您的模型包含对象的引用。因此最后一行是无用的,它根本不会改变任何东西。它简单地等同于:

this.get('attr_array')[1].state = 'active';

当你使用 set 时,你会丢失 Backbone 所做的任何内部工作。
那么该怎么办?克隆你的对象:

var array = _.clone(this.get('attr_array'));
array[1].state = 'active';
this.set('attr_array', array); // will trigger 'change' and 'change:attr_array' events

关于javascript - 在 Backbone 中使用 model.set 更改嵌套属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16084661/

相关文章:

javascript - 模型销毁调用不正确的 REST url

javascript - 将两个整数之间的所有数字相加

java - JsonIgnore 和 XmlElement 注释冲突

javascript - 如何在 Javascript 中计算对象数组内的值?

javascript - 将 PostGIS 点对象转换为 geoJSON 以进行制图

json - 将 webGL(ThreeJS) 与常规 HTML/CSS 网站混合

javascript - Backbone.js : Changing view. 属性没有反射(reflect)在 view.el 上

javascript - 排队表单提交请求直到服务器返回

javascript - 循环遍历集合,根据操作属性将每个项目推送到新集合

javascript - Jquery如果div不存在