即使成功,Backbone.js save也始终会触发错误

时间:2014-03-11 01:37:19

标签: backbone.js

我已经阅读了有关此问题的其他几篇文章,但似乎没有任何解决方案适合我。我的视图中有以下代码:

  this.model.set({
      username: $('#user-username').val(),
      role: $('#user-role').val(),
      description: $('#user-description').val()
  });

  this.model.save({ user_id: this.model.get('user_id')}, {
    success: function(user, response) {
      console.log('success:', response);
      $('.flash-message').text("Success").show();
    }, 
    error: function(user, response) {
      console.log('error:', response);
      $('.flash-message').text(response.error).show();
    } 
  });

这在我的服务器控制器上(nodejs运行express 3):

UserController.prototype.updateAction = function(req, res) {
if (req.route.method != "put") {                              
    res.send({status: "error", error: "update must be put action and must include values"});
    return false;                                             
}
var query = {'user_id': req.params.id};                       
var user = req.body;
var userRepository = this.userRepository                      

// delete _id to avoid errors
delete user._id;

userRepository.update(query, user, {}, function(err, updated) {
    if ((err) || (!updated)) {
        res.send({"status": "error", "error": err});
        return false;
    }
    // send updated user back
    util.log('updated user ' + user.user_id);
    res.setHeader('Content-Type', 'application/json');
    res.status(200);
    res.send(JSON.stringify({"status": "success", "updated": updated}));
});

}

保存时,我的模型已正确保存在服务器中,我已使用this验证了服务器响应。所以,据我所知,服务器返回状态200,有效的JSON,带有有效的JSON响应头。然而我的主干model.save函数总是触发错误回调。谁能告诉我为什么以及如何解决这个问题?

如果将dataType设置为文本,我可以使其工作:

this.model.save({ user_id: this.model.get('user_id')}, {
    dataType: "text",
    success: function(user, response) {
      console.log('success:', response);
      $('.flash-message').text("Success").show();
    }, 
    error: function(user, response) {
      console.log('error:', response);
      $('.flash-message').text(response.error).show();
    }
  });

但这样做不允许我从服务器获取响应。相反,我在响应var:

中得到了这个
success: {
  "_id": "5133b02062e15ed1d2000001",
}

3 个答案:

答案 0 :(得分:1)

Backbone希望找回它在PUT或POST请求体中发送的模型。

而不是:

res.send(JSON.stringify({"status": "success", "updated": updated}));

在服务器的回复中尝试此操作:

res.json(user);

答案 1 :(得分:0)

您的呼叫可能已经建立了状态200连接,哪个骨干网检测到错误,Backbone仅在呼叫为200OK时才会成功。

答案 2 :(得分:0)

你的服务器代码是什么?您需要确保将json发送回骨干,如下所示:

//In your express POST route
user.save(function(err) {
    if(err){
        console.log(err);
        return res.json(401);
    } else {
        console.log('user: ' +user.username + ' saved');
        return res.json(200);
    }

然后在您的骨干视图中,您可以检查响应并执行您需要的操作:

//some function in your view
this.model.save(this.formValues, {
            success: function(model, response, options) {
                if (response == 200) { 
                    console.log('success :' + response);
                    //Do stuff
                } else {
                    console.log('error: '+response);
                //etc.

另请注意,根据骨干模型文档: “save接受选项哈希中的成功和错误回调,它将传递参数(模型,响应,选项)”