jQuery Deferred and Promise para la ejecución secuencial de funciones síncronas y asíncronas
Si quisiera que las funciones síncronas y asíncronas se ejecutaran en un orden particular, podría usar la promesa jQuery, pero parece que no funciona de la manera que esperaría que funcionara.
Las funciones a, b y c deben ejecutarse en ese orden cuando en undeferred.resolve()
se llama Espero que la función b se ejecute, pero todas las funciones se ejecutan inmediatamente, no importa si se llama a la resolución.
Aquí está el código:
function a(){
var deferred = $.Deferred();
setTimeout(function(){
console.log("status in a:",deferred.state());
//this should trigger calling a or not?
deferred.resolve("from a");
},200);
console.log("a");
return deferred.promise();
};
function b(){
var deferred = $.Deferred();
setTimeout(function(){
console.log("status in b:",deferred.state());
deferred.resolve("from b");
},200);
console.log("b");
return deferred.promise();
}
//synchronous function
function c(){
var deferred = $.Deferred();
console.log("c");
console.log("status in c:",deferred.state());
deferred.resolve("from c");
return deferred.promise();
}
function test(){
fn=[a,b,c],i=-1,
len = fn.length,d,
d = jQuery.Deferred(),
p=d.promise();
while(++i<len){
p=p.then(fn[i]);
}
p.then(function(){
console.log("done");
},
function(){
console.log("Failed");
});
d.resolve();
//instead of the loop doing the following has the same output
//p.then(a).then(b).then(c);
//d.resolve();
}
test();
La salida es:
a
b
status in c: pending
c
done
status in a: pending
status in b: pending
Rendimiento esperado:
a
status in a: pending
b
status in b: pending
c
status in c: pending
done
Probé algunas combinaciones de las siguientes modificaciones:
d = jQuery.Deferred();
setTimeout(function(){d.resolve();},100);
var p=d.promise();
while(++i<len){
p.then(fn[i]);
}
Pero todos con los mismos resultados inesperados, b se llama antes de que se aplace diferido de a, se llama c antes de que se resuelva el diferido de b.