繁体   English   中英

如何从fetch返回ajax结果

[英]How return ajax results from fetch

我修改了我的集合覆盖了fetch方法,但是fetch没有返回任何内容。

var Friendscollection = Backbone.Collection.extend({


model:Person,
url:"https://api.parse.com/1/classes/_User/",
idAttribute: "objectId",
parse: function(data) {

    return data.results;
},



initialize:function(){

   },

fetch: function(options) {
        var cur_user= Parse.User.current().id;           
          var res;  
     var ajax = $.ajax;        
   $.ajax({
//query rest che trova tutti gli amici dell'utente corrente        
type: 'GET',
async: false,
headers: {'X-Parse-Application-Id':'qS0KLM--h***PiTS3VMk','X-Parse- 
REST-API-Key':'nh3eoUo***Tks9--JIfIt1Gm'},
url: "https://api.parse.com/1/classes/_User/?where={%22$relatedTo%22:\n\
   {%22object%22:}",

success: function(data) {
    //  console.log(data );
      res=data;


    },
    error: function(data) {

      console.log("ko" );
    }


  });

      console.log(res); 
  return res;     





}


});



 return Friendscollection;



 });

如果调用fetch,则返回空集合:

 Friends.utenti = new Friendscollection();
 Friends.utenti.fetch({async:false});

Backbone.Collection.fetch方法不应该返回数据,而是返回deferred或promise对象。 做你想做的正确方法是这样的:

var Friendscollection = Backbone.Collection.extend({
    model: Person,
    url: "https://api.parse.com/1/classes/_User/",
    idAttribute: "objectId",
    parse: function(data) {

        return data.results;
    },

    fetch: function(options) {
        var cur_user = Parse.User.current().id;
        return Backbone.Collection.prototype.fetch.call(this, {
            type: 'GET',
            headers: {
                'X-Parse-Application-Id': 'qS0KLM--h***PiTS3VMk',
                'X-Parse-REST-API-Key': 'nh3eoUo***Tks9--JIfIt1Gm'
            },
            url: this.url + "?where=..."
        });
    }
});

有了它,你可以得到这样的ajax结果:

var friendscollection = new FriendsCollection();
var res;

friendscollection.fetch().done(function(data) {
    res = data;
}).fail(function(xhr, textStatus, error) {
    console.log(textStatus);
});

该代码是异步的,因此您不应期望在同一个块中定义res 这就是done()的回调。 要了解有关延迟对象如何工作的更多信息,请查看Deferred对象

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM