3

我正在使用主干本地存储插件创建一个基于主干示例的小型应用程序。

为新模型保存数据时,我总是收到错误“必须指定“url”属性或函数

在阅读了几个类似的主题后,我仍然无法找到原因。

模型:

directory.models.EmployeeCollection = Backbone.Collection.extend({

    localStorage: new Backbone.LocalStorage("EmployeeCollection"), 

    model: directory.models.Employee,

    store: directory.utils.store,

    findByName: function(key) {
        this.reset(this.store.findByName(key));
    }

});

风景:

directory.views.newEmployeeView = Backbone.View.extend({

    tagName: "div",

    initialize: function() {
        this.template = _.template(directory.utils.templateLoader.get('new-employee'));
    },

    events: {
        "click .save": "saveEmployee"
    },

    render: function(eventName) {
        $(this.el).html(this.template(this.model.toJSON()));
        return this;
    },

    saveEmployee: function(event){
        this.model.set({
            firstName:$('#newFirstName').val(),
            lastName:$('#newLastName').val(),
            title:$('#newTitle').val(),
            city:$('#newCity').val(),
            officePhone:$('#newOfficePhone').val(),
            cellPhone:$('#newCellPhone').val(),
            email:$('#newEmail').val()
        });

        this.model.save();
        window.history.back();

        return false;
    }
});
4

1 回答 1

3

我认为在尝试持久化之前,您需要新模型成为您的集合的成员。尝试创建一个集合的新实例并将其传递给视图(可能在您的路由器中),如下所示:

new newEmployeeView({ collection: new EmployeeCollection() });

在您看来,您可以使用 Backbone 的 create 便捷方法(请参阅docs)将模型的新实例添加到集合中并将其持久化:

this.collection.create({
    firstName:$('#newFirstName').val(),
    lastName:$('#newLastName').val(),
    title:$('#newTitle').val(),
    city:$('#newCity').val(),
    officePhone:$('#newOfficePhone').val(),
    cellPhone:$('#newCellPhone').val(),
    email:$('#newEmail').val()
});
于 2013-05-30T14:09:39.200 回答