0

RSVP で単純な jQuery promise をラップしていますが、意図的にエラーを発生させた場合、失敗コールバックが呼び出されないことに気付きました。バニラjQueryを使用し、コールバックがエラーをスローすると、返されたプロミスが失敗状態に移行しないためだと思います(仕様の反対)。

jQuery $.ajax を使用する必要があるが、RSVP で真の解決/拒否コールバックを取得したい場合、以下の例に対して何ができますか?

var peoplePromise = new Ember.RSVP.Promise(function(resolve, reject) { 
    $.getJSON('/api/people/', resolve).fail(reject).error(reject);     
});                                                                    

var catPromise = new Ember.RSVP.Promise(function(resolve, reject) {    
    $.getJSON('/api/cats/', resolve).fail(reject).error(reject);       
});                                                                    

Ember.RSVP.all([peoplePromise, catPromise]).then(function(things) {    
    things[0].forEach(function(hash) {                                 
        var thing = App.Person.create(hash);                           
        Ember.run(self.people, self.people.pushObject, thing);         
    });                                                                
    things[1].forEach(function(hash) {                                 
        var wat = hash.toJSON(); //this blows up                                      
        var thing = App.Person.create(hash);                           
        Ember.run(self.people, self.people.pushObject, thing);         
    });                                                                
}, function(value) {                                                   
    alert(value.status + ": promise failed " + value.responseText);    
});
4

1 に答える 1

2

例: http://www.youtube.com/watch?feature=player_detailpage&v=g5CSaK3HqVA#t=1080

var ajaxPromise = function(url, options){
  return Ember.RSVP.Promise(function(resolve, reject) {

    var options = options || {};

    options.success = function(data){
      resolve(data);
    };

    options.error = function(jqXHR, status, error){
      reject([jqXHR, status, error]);
    };

    $.ajax(url, options);
  });
};

var peoplePromise = ajaxPromise('/api/people/',{
  dataType: "json"
});

var catPromise = ajaxPromise('/api/cats/',{
  dataType: "json"
});

Ember.RSVP.all([peoplePromise, catPromise]).then(function(things) {
  things[0].forEach(function(hash) {
    var thing = App.Person.create(hash);
    Ember.run(self.people, self.people.pushObject, thing);
  });
  things[1].forEach(function(hash) {
    var wat = hash.toJSON(); //this blows up
    var thing = App.Person.create(hash);
    Ember.run(self.people, self.people.pushObject, thing);
  });
}, function(args) {
  var jqXHR = args[0];
  alert(jqXHR.status + ": promise failed " + jqXHR.responseText);
});

http://emberjs.jsbin.com/aREDaJa/1/

于 2013-10-09T21:25:32.830 に答える