2013-12-21 52 views
0

为什么无法在model.save中获取更新请求?我总是得到创建请求。backbonejs model.save的创建或更新 - 无法获取更新请求

观点,

define([ 
    // load the dependencies 
], function(App, $, _, Backbone, Handlebars, ProjectModel, ProjectCollection){ 

    var updateFormView = Backbone.View.extend({ 

     el: 'div.abPanel', 

     initialize: function() { 
      $(this.el).undelegate('form#frmAddContact', 'submit'), 
      _.bindAll(this, 'updateContactPage', 'updateContact'); 
     }, 


     events: { 
      'submit form#frmAddContact': 'updateContact' 
     }, 

     updateContactPage: function (id) { 

      // load the data into the update form 

     }, 

     updateContact: function (event) { 

      var contactmodel = new ProjectModel({ 
       form: $('#frmAddContact', this.$el) 
      }); 

      contactmodel.save(); 
      return false; 
     } 
    }); 

    return updateFormView; 
}); 

型号,

var ProjectModel = Backbone.Model.extend({ 
     sync: function (method, model, options) { 
      console.log(method); // Why I always get create method?? 
      // other stuff 
     } 
    }); 


    return ProjectModel; 
}); 

在骨干doc

通知我们Backbone.sync的重写版本如何接收一个 “创造” 要求第一模型保存时间和“更新”请求 第二次。

second time?我不明白 - 为什么我们需要在second time处获得“更新”要求?我不能从集合中获取特定的模型数据,编辑并更新它?

编辑:

updateContactPage: function (id) { 

      var contact = {}; 
      var model; 


      if(App.contactCollection !== undefined) 
       model = App.contactCollection.get(id); // I have called the model first time right??? 


      if (id !== undefined && model !== undefined) { 

       console.log(model); // And I get the requested model displayed on my form. 
       contact = model.toJSON(); 
      } 
      this.$el.html(Handlebars.getTemplate('add')({contact: contact})); 

     }, 
+2

你设置的一个'id'属性有问题的Backbone.Model? – fbynite

+0

是的,我有。请看看我上面的编辑。我第一次在集合中调用模型。除非我理解错第一次和第二次意味着骨干? – laukok

+1

第一次被翻译成一个'PUT'请求(即''保存'一个没有'id'属性的模型]。第二次被转换成一个'POST'请求(也就是说,你保存一个具有'id'属性的模型)。总之'App.contactCollection.get(id)!=(第一次||第二次)'。 – fbynite

回答

0

要获得update要求,我只需要设置/发送一个ID,型号,

updateContact: function (event) { 

      var contactmodel = new ProjectModel({ 
       id:38, // set an id here for updating 
       form: $('#frmAddContact', this.$el) 
      }); 

      contactmodel.save(); 
      return false; 
     }