[英]Node.js Promise Chain not firing in desired order
我创建了一个Promise链的简单示例。 我的目标是触发以下4个函数以按顺序获取输出。 即1 2 3 4。
function WriteOne()
{
return new Promise(function(resolve, reject)
{
console.log("1");
resolve("true");
})
}
function WriteTwo()
{
return new Promise(function(resolve, reject)
{
setTimeout(function(){console.log("2");}, 3000);
resolve("true");
})
}
function WriteThree()
{
return new Promise(function(resolve, reject)
{
setTimeout(function(){console.log("3");}, 1000);
resolve("true");
})
}
function WriteFour()
{
return new Promise(function(resolve, reject)
{
console.log("4");
resolve("true");
})
}
WriteOne().then(WriteTwo).then(WriteThree).then(WriteFour);
当我执行它们时,它们按以下顺序触发:
1 4 3 2
我在这里做错了什么?
您需要resolve
setTimeout
回调内部
function WriteOne() { return new Promise(function (resolve, reject) { console.log("1"); resolve("true"); }); } function WriteTwo() { return new Promise(function (resolve, reject) { setTimeout(function () { console.log("2"); resolve("true"); }, 3000); }); } function WriteThree() { return new Promise(function (resolve, reject) { setTimeout(function () { console.log("3"); resolve("true"); }, 1000); }); } function WriteFour() { return new Promise(function (resolve, reject) { console.log("4"); resolve("true"); }); } WriteOne().then(WriteTwo).then(WriteThree).then(WriteFour);
这里没问题,这里发生了什么:
// t=0s
writeOne()
// 1 is logged
// promise is resolved
.then(writeTwo)
// in 3s, 2 will be logged
// promise is resolved
.then(writeThree)
// in 1s, 3 will be logged
// promise is resolved
.then(writeFour)
// 4 is logged
// t=1s
// 3 is logged
// t=3s
// 2 is logged
因此输出。
为了获得您期望的结果,请在setTimeout中解析promise。
在console.log()
之前调用resolve("true")
因为它在setTimeout()
。
由于WriteOne()
和WriteFour()
没有超时,因此“ 1”和“ 4”首先出现。 然后在1秒钟后“ 3”,然后2。
您必须输入resolve("true");
在setTimeout()
里面以便使它们按顺序出现。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.