如何覆盖Backbone的解析函数?

时间:2012-08-20 12:49:24

标签: javascript backbone.js

我尝试在项目中使用骨干。但是当我尝试覆盖Backbone的解析方法时遇到了问题。服务器发回的数据比我想要的多。例如: 我想要的是:

[{
   id: "123",
   name: "david"
},{
   id: "456",
   name: "kevin"
}]

但服务器的结果是:

{
 total: 1000,
 items:[{
   id: "123",
   name: "david"
},{
   id: "456",
   name: "kevin"
}]
}

所以我想在parse方法中处理结果并只返回数组。我怎样才能做到这一点?当我尝试我得到错误。我该怎么办?

2 个答案:

答案 0 :(得分:7)

在骨干模型中,按照您希望的方式定义解析函数:

Model = Backbone.Model.extend({
    parse: function () {
        return {
            id: this.get("id"),
            name: this.get("name")
        }
    }
});

但是,最好在模型初始化程序中处理和设置数据,如下所示:

Model = Backbone.Model.extend({
    initialize: function (attrs) {
        try {
            //TODO HERE: test for correct values and throw errors

            // set object variables here
            this.set({
                name: attrs.name,
                id: attrs.id
            });

        } catch (e) {
            console.log(e);
        }
    }
});

现在无需覆盖解析函数。这样您就可以知道模型正在处理的数据是好的,并且您可以设置它包含的变量。这可以避免无效数据导致的许多错误。

数组中的每个项目都应该是一个子模型,这就是我上面写的。您的父模型应如下所示:

Model = Backbone.Model.extend({
    initialize: function (items) {
        this.subModels = [];
        items.forEach(function (item) {
            this.subModels.push( new SubModel(item) )
        });
    }
});

或作为集合:

Collection = Backbone.Collection.extend({
    model: ItemModel,
});

您将通过response.items

答案 1 :(得分:4)

来自Backbone Parse docs

Collection = Backbone.Collection.extend({
    model: YourModel,
    parse: function(response){
        return response.items;
    }
});