0

我有一个像这样的骨干模型

define([
'underscore',
'backbone'
],function( _,Backbone) {
    var Task =  Backbone.Model.extend({
        //api url
        url:'',

        methodToURL: {
        'read': './api/tasks/index',
        'create': './api/tasks/task',
        'update': './api/tasks/task',
        'delete': './api/tasks/task'
        },
        sync: function(method, model, options) {
            options = options || {};
            options.url = this.methodToURL[method.toLowerCase()];

            Backbone.sync(method, model, options);
        }
    });
    return Task;
});

和一个集合

define(['underscore','backbone','models/task'],function( _,Backbone,Task) {
    var TaskCollection = Backbone.Collection.extend({
        //Model
        model:Task,
        //api url
        url:'',

        methodToURL: {
        'read': './api/tasks/index',
        'create': './api/tasks/task',
        'update': './api/tasks/task',
        'delete': './api/tasks/task'
        },

        sync: function(method, model, options) {
            options = options || {};
            options.url = this.methodToURL[method.toLowerCase()];

            Backbone.sync(method, model, options);
        },
        //construct
        initialize: function() {
            this.sort_key = 'end';
            this._model = new Task();
            this.fetch();
        },

        comparator: function(a,b) {
            a = a.get(this.sort_key);
            b = b.get(this.sort_key);
            return a > b ?  1
                 : a < b ? -1
                 :          0;
        },

        mark_complete: function(task_id) {
            var task_status = 0;
                    console.log(this.model);
            this.model.save({id:task_id,task_status:task_status});
        },

        mark_incomplete: function(task_id) {
            var task_status = 1;
                    console.log(this.model);
            this.model.save({id:task_id,task_status:task_status});
        },

        sort_by_status: function() {
            this.sort_key = 'task_status';
            this.sort();
        },

        sort_by_task_tag: function() {
            this.sort_key = 'task_group';
            this.sort();
        }
    });
    return TaskCollection;
});

当我运行 mark_complete 方法时,模型会记录到控制台,但它会记录这个“ function (){ parent.apply(this, arguments); }”并说“ function (){ parent.apply(this, arguments); } has no method 'save'”;我猜测该模型应该被实例化,以便集合可以访问它的方法,那么出了什么问题?

4

1 回答 1

2

model属性只是Collection在将模型添加到集合时使用的构造函数。当您尝试将数据输入到集合中时,它旨在让您的生活更轻松。Task在向 中添加模型时,不必总是调用构造函数TaskCollection,您只需输入一个 JavaScript 对象,它就会做同样的事情。

因此,当您想要插入模型而不model属性设置为您的TaskCollection

taskCollection.add(new Task({ 
    name: "Get Milk",
    description: "We're out of milk. There's a sale going on at the local supermarket." 
}));

// If you wanted to just input just the JSON object without calling the
// constructor, then you can't.

如果您设置了属性model,这就是您的代码的样子

taskCollection.add({
    name: "Get Milk",
    description: "We're out of milk. There's a sale going on at the local supermarket." 
});

如您所见,您不需要调用Task构造函数;的实例TaskCollection将为您调用它。

这就是为什么实例TaskCollection只会将model属性设置为的实际构造函数Task,而不是初始化版本。

于 2012-07-21T16:37:15.340 回答