使用新的数组元素更新backbone.js模型

Update backbone.js model with new array element

本文关键字:backbone js 模型 更新 数组元素      更新时间:2023-09-26

我有一个类似于下面所示的backbone.js模型。

Filters = Backbone.Model.extend({
    defaults : {
        title: [ ["title1", "easy"], ["title2", "hard"] ]
    }
});

我试图在第一级数组中添加一个元素,这样模型就变成了:

Filters = Backbone.Model.extend({
    defaults : {
        title: [ ["title1", "easy"], ["title2", "hard"], ["title3", "medium"] ]
    }
});

我现在的代码是:

function setFilters() { 
    var options = {};   
    for (var facet in facets) {
        for (var facetKey in facets[facet]) {
            if (!filterExists(facetKey)) {
                options[facetKey] = new Array(new Array(facets[facet][facetKey], "equals"));
            }
            else {
                (filters[facetKey]).push(new Array(facets[facet][facetKey], "equals"));
            }
        }
    }
    filters.set(options);
}

函数filterExists只是检查键"title"是否存在于模型中。当我运行这个时,它说过滤器[facetKey]是未定义的。但这不是我需要将元素推入的第一级数组吗?

您可以使用.get().set()函数访问模型属性,也可以直接通过.attributes属性访问:

http://documentcloud.github.com/backbone/#Model-属性

var filters = new Filters();
filters.attributes.facetKey.push( [...] );

filters.set('facetKey', ( filters.get('facetKey') || []).concat([...]));

不管怎样,这是你转换后的函数,它可能起作用,也可能不起作用:

function setFilters() { 
    for (var facet in facets) {
        for (var facetKey in facets[facet]) {
            var f = [ facets[facet][facetKey], "equals" ];
            if( filterExists(facetKey)) {
            // OR: if( filters.attributes[ facetKey ]){
                filters.attributes[ facetKey ].push( f );
            }else{
                filters.attributes[ facetKey ] = [ f ];
            }
        }
    }
    // trigger change event for all attributes
    filters.set( filters.attributes );
}

奖金:

(filters.attributes[ facetKey ] = filters.attributes[ facetKey ] || [] ).push(f);