Backbone model.save() is sending PUT instead of PO

2020-02-27 00:25发布

I call save using this:

console.log(this.model.isNew());
console.log(this.model);

this.model.save({}, {
    success: function (model, response, options) {
        console.log(response);
    },
    error: function (model, xhr, options) {
        console.log(xhr.result.Errors);
    }   
});

The isNew() returns false. But the output of this.model has an ID of 0. (this.model.id is 0 as well)

My url is url: ROOTAREA + "/Expenses/Entry/",

Updating works fine, and uses PUT as expected.

Edit : here's part of my model:

   defaults: function () {
        return {
            DocumentDate: "",
            JobNo_: "",
            PhaseCode: "",
            WorkTypeCode: "",
            Description: "",
            Quantity: 0,
            UnitCost: 0,
            ExpenseCurrencyCode: "",
            ReimbursementCurrencyCode: "",
            UnitofMeasureCode: "DIEM",
            LineNo_: 0
        };
    },
    idAttribute: "LineNo_",

3条回答
一纸荒年 Trace。
2楼-- · 2020-02-27 00:42

The above answers are correct in that if the model you are .save'ing has an id attribute backbone will do a PUT rather than a POST.

This behavior can be overridden simply by adding type: 'POST' to your save block:

var fooModel = new Backbone.Model({ id: 1});

fooModel.save(null, {
  type: 'POST'
});
查看更多
迷人小祖宗
3楼-- · 2020-02-27 00:46

ID should not even exist for a new entry. The issue is in the part you didn't show - in the part where you instantiate, create and populate the model.

Here is a quote from the Backbone documentation:

If the model does not yet have an id, it is considered to be new.

It is clear from your code that you are assigning an id attribute. Your backend should be doing that. And since you are doing it on a client, backbone presumes it it not new, and uses PUT

查看更多
\"骚年 ilove
4楼-- · 2020-02-27 00:48

You can specify the ID in defaults, just make sure it's set to null (isNew will be set to true).

In your case it must be

LineNo_: null
查看更多
登录 后发表回答