BackboneJS,为什么取不到数据?

发布于 2022-08-27 12:58:07 字数 600 浏览 10 评论 0

刚接触Backbone,参考API文档和一些样例,写了一段代码从后台取数据。但是Collection.fetch()虽然发起了AJAX请求,但是Collection本身却一直是空的,没有数据填充进来。我override了Backbone.sync直接返回数据,也仍然是空的。

是少了什么?还是Resonse必须符合某种结构?

var Message = Backbone.Model.extend({});
var MessageStore = Backbone.Collection.extend({
    model: Message,
    url: '/messages'
});
Backbone.sync = function() {
    return [{"content":"Hi there","id":1},{"content":"How are you?","id":2}];
}
var messages = new MessageStore;
messages.fetch();
console.log(messages.length);          // 0
console.log(JSON.stringify(messages)); // []

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

回心转意 2022-09-03 12:58:07

在stackoverflow上发的问题有哥们先答了。简短洁说,Collection.fetch()是异步的...

messages.fetch({success:function(){
  console.log(messages.length);          // 1
  console.log(JSON.stringify(messages)); // [foo:'bar']
}});
春夜浅 2022-09-03 12:58:07

你犯了一个致命错误,fetch是异步的,但是你的LOG却是直接输出,也就是说,即便fetch到了,你的输出仍然还会是空。


你找到答案了= =,忽略我吧

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文