5

我要么非常疲倦,要么真的很困惑......但我不确定......我有一个 parse.com javascript 设置(它与backbone.js 完全一样,只是使用解析而不是主干)。我有一个模型和一个系列,这一切都有效。但是该死的 toJSON(); 不起作用,它只会在 console.log 中返回一个 [] ...但是,如果我在 Chrome 控制台中运行相同的函数,它会起作用并返回正确的值。

有什么帮助!?

所有这些可爱的代码都包装在一个准备好的文档中(并且它还有一些其他的不相关的代码,是的,我已经完成Parse.initialize()了它。

  var Schedule = Parse.Object.extend({
    className: "schedule"
  });

  var ScheduleList = Parse.Collection.extend({
    model: Schedule
  });

   schedule = new ScheduleList();
      schedulejs3 = schedule.toJSON();
      schedule.query = new Parse.Query(Schedule);
      schedule.query.ascending("date");
      schedule.query.limit('500');
      schedulejs2 = schedule.toJSON();
      schedule.fetch();

      schedulejs = schedule.toJSON();
      console.log(schedulejs,schedulejs2,schedulejs3); <-- All three return []

  var ScheduleView = Parse.View.extend({
    el: $("#schedule-holder"),
    initialize: function() {
      this.schedule = new ScheduleList();
      this.schedule.query = new Parse.Query(Schedule);
      this.schedule.query.ascending("date");
      this.schedule.query.limit('500');

      this.schedule.fetch();

      this.schedule.js = this.schedule.toJSON();

      this.render;
    },

    render: function() {
      var template = Handlebars.compile($("#schedule-item").html());
      $(this.el).html(template({shows: this.schedule.toJSON()}));
      return this;
    }
  });

  var App = new ScheduleView().render();

但是如果我在 Chrome 中打开控制台并运行 schedule.toJSON(); 我得到了正确的值......正如你所看到的,我已经试图解决这个问题(以防你想知道为什么一切都在这个地方)。还有一点需要注意的是,我使用的是 Zepto.js 而不是 jQuery。

谢谢!

4

1 回答 1

19

可能在您执行schedule.toJSON()时它仍然是空的。

请记住,这Collection.fetch()是一个异步方法。

尝试修改这一行:

schedule.fetch();

这样:

schedule.fetch({ success: function() { console.log( "what about now?", schedule.toJSON() ) } };

(可能您会遇到上下文问题,尝试使schedule变量可以访问 success处理程序)

于 2012-08-29T13:17:58.080 回答