在Backbone模型中存储/推送到阵列

时间:2012-11-30 11:11:01

标签: backbone.js

我有这个型号默认值:

test.Models.ItemModel = Backbone.Model.extend({

defaults: {
    name: 'an item',
    units: []
},

然后我使用以下代码来设置模型:

 addUnit: function(e){
    if(e.keyCode == 13){
      this.model.set({ 'units' : this.model.get('units').push($('#addUnit').val()) }, 
        {success: function(){
          this.render();
        }}
      );
    }
  },

然而,它似乎永远不会被添加到Model数组中,我在这里做事吗?

1 个答案:

答案 0 :(得分:8)

问题是你假设push方法正在返回整个数组;相反,as stated herepush方法

  

返回调用该方法的对象的新length属性。

因此,在将元素设置为模型之前,需要将元素推入数组中:

var _units = this.model.get('units');
_units.push($('#addUnit').val());
this.model.set({ 'units' : _units });  

小心,这会修改指向此数组的任何其他内容,因此如果您这样做,例如:

var myArray = [1,2,3]
this.model.set({units: myArray})
var _units = this.model.get('units')
_units.push(4)
this.model.set({ 'units' : _units })
myArray == this.model.get('units') // holy moly, they're the same :(

如果你想避免这种情况,或者仍想使用单行代码,你可以使用数组的concat method

this.model.set({ 
    'units' : this.model.get('units').concat($('#addUnit').val())
});