javascript - 如何重写Backbone的解析函数?

标签 javascript backbone.js

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

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

但服务器的结果是:

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

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

最佳答案

在您的主干模型中,按照您想要的方式定义解析函数:

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

关于javascript - 如何重写Backbone的解析函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12037984/

相关文章:

javascript - JQuery:向 anchor 元素添加 onClick 函数

javascript - 使用确认模式删除数据

Javascript 创建二维数组,以 ids 作为数组键

javascript - `void 0` 是什么意思?

javascript - Coffeescript 的主干上下文问题

javascript - Backbone 模型责任

javascript - 寻找 。正则表达式中的字符问题

javascript - 跨平台、跨浏览器的 Javascript 性能分析

javascript - Uncaught Error : Method "undefined" does not exist backbone. js:1291

django - 我如何从 Tastypie JSON 访问 Backbone 集合元素?