我正在开发一个 Web 应用程序,该应用程序由使用 Python 的 CherryPy 框架编写的 restful API 提供支持。我开始使用 jQuery 和服务器端模板的组合来编写用户界面,但最终切换到 Backbone.js,因为 jQuery 失控了。
不幸的是,我在让我的模型与服务器同步时遇到了一些问题。这是我的代码中的一个简单示例:
$(function() {
var User = Backbone.Model.extend({
defaults: {
id: null,
username: null,
token: null,
token_expires: null,
created: null
},
url: function() {
return '/api/users';
},
parse: function(response, options) {
console.log(response.id);
console.log(response.username);
console.log(response.token);
console.log(response.created);
return response;
}
});
var u = new User();
u.save({'username':'asdf', 'token':'asdf'}, {
wait: true,
success: function(model, response) {
console.log(model.get('id'));
console.log(model.get('username'));
console.log(model.get('token'));
console.log(model.get('created'));
}
});
});
正如您可能知道的那样,这里的想法是向该服务注册一个新用户。当我打电话时u.save();
,Backbone 确实向服务器发送了一个 POST 请求。以下是相关位:
要求:
Request URL: http://localhost:8080/api/users
Request Method: POST
Request Body: {"username":"asdf","token":"asdf","id":null,"token_expires":null,"created":null}
回复:
Status Code: HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 109
Response Body: {"username": "asdf", "created": "2013-02-07T13:11:09.811507", "token": null, "id": 14, "token_expires": null}
如您所见,服务器成功处理了请求并返回了id
和 的值created
。但是由于某种原因,当我的代码调用时console.log(u.id);
,我得到null
了,当我的代码调用时console.log(u.created);
,我得到了undefined
.
tl;dr:为什么 Backbone.js 在调用后不持久更改我的对象save()
?
编辑:
我修改了上面的代码,以便在success
回调中使用 get 函数访问模型属性。这应该可以解决原始代码的任何并发问题。
我还在模型的parse
功能中添加了一些控制台日志记录。奇怪的是,每一个都是undefined
......这是否意味着 Backbone.js 无法解析我的响应 JSON?
编辑 2: 几天前,我发现这个问题实际上是一个自定义标头,我添加到每个请求中以启用 HTTP 基本身份验证。有关详细信息,请参阅此答案。