- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在带有 Q
Promise
的 Node.js
应用程序中,我有这段代码,我想看到这个结果:
a
b
end
但我看到了这个:
end
a
b
这是我的代码:
var a = function(){
return q.Promise(function(resolve, reject){
resolve("a");
});
};
var b = function(){
return q.Promise(function(resolve, reject){
resolve("b");
});
};
var c = function(){
return q.Promise(function(resolve, reject){
resolve("c");
});
};
var master = q();
master.then(function(){
return a();
})
.then(function(res){
console.error(res);
return b();
})
.then(function(res){
console.error(res);
return c();
});
master.then(function(){
console.error("end");
});
如果我更改此部分:
master.then(function(){
return a();
})
对此:
master = master.then(function(){
return a();
})
代码工作正常,但我不知道为什么?了解和理解这一点对我来说很重要。有人可以向我解释一下吗?
最佳答案
您所看到的是链接和分支之间的区别,它们是不同形式的 Promise 控制流。
当你这样做时:
master.then(function(){
return a();
})
然后:
master.then(function(){
console.error("end");
});
您已将两个 .then()
处理程序挂接到同一个 Promise。这是分支。当 master()
被解析时,这些 .then()
处理程序中的每一个都将被相互独立地调用,并且每个处理程序都成为自己的独立链(因此原始链是 <强>分支成两条链)。
链接就像:
master.then(function(){
return a();
}).then(function(){
console.error("end");
});
在链接情况下,直到 a()
返回的任何 Promise 也得到解析并且如果 a ()
抛出或返回一个被拒绝的 Promise,这里的第二个 .then()
处理程序根本不会被调用。
在第一个示例的分支情况中,无论 是什么,都会在第一个
返回。.then()
处理程序之后立即调用第二个 .then()
处理程序a()
当你这样做时:
master = master.then(function(){
return a();
})
在此之前:
master.then(function(){
console.error("end");
});
您正在手动链接它们,以便您有效地完成:
master.then(function(){
return a();
}).then(function(){
console.error("end");
});
请记住,每次调用 .then()
都会返回一个新的 Promise。链接,如:
a().then(b).then(c)
在链中的每个步骤创建一个新的 Promise,并且在处理程序返回的任何内容也得到解决之前,该新的 Promise 不会得到解决。
所以,当你这样做时:
master = master.then(function(){
return a();
})
你正在捕获中间的 promise (通过分配给master
)并捕获它,这样你就可以将一些东西链接到它上面。如果你这样做:
master.then(function(){
return a();
})
然后,从 master.then()
返回的 Promise 就完成了,不能直接链接到上面。
有关链接与分支的进一步描述,请参阅这些帖子:
Understanding javascript promises; stacks and chaining
Is there a difference between promise.then.then vs promise.then; promise.then
<小时/>这是显示 Promise 分支的代码片段:
function log(str) {
var d = document.createElement("div");
d.textContent = str;
document.body.appendChild(d);
}
function setDelay(t, msg) {
return function() {
return delay(t, msg);
}
}
function delay(t, msg) {
// if only one string argument, default t to 500ms
if (typeof t === "string" && typeof msg === "undefined") {
msg = t;
t = 500;
}
return new Promise(function(resolve) {
setTimeout(function() {
log(msg);
resolve(msg);
}, t);
});
}
var x = Promise.resolve().then(setDelay("One"))
.then(setDelay("Two"))
.then(function() {
log("Three");
});
x.then(setDelay(500, "Four"))
.then(setDelay(500, "Five"))
.then(setDelay(500, "Six"));
x.then(setDelay(50, "Seven"))
.then(setDelay(50, "Eight"))
.then(setDelay(50, "Nine"));
x.then(setDelay(10, "Ten"))
.then(setDelay(10, "Eleven"));
说明
一、二、三链接在一起,所有分支都依赖于它们。然后,该链分成三个独立的分支。
十、十一分支首先执行,因为它有 10 毫秒计时器。
然后,七、八、九分支接下来使用 50 毫秒计时器。
然后,四、五、六分支最后使用 500ms 计时器
注意:我故意这样做,这样分支计时器就不会重叠,但这不是 promise 强制执行的,因为我选择的计时器值恰好是这种情况。所有三个分支都独立运行,如果它们的事件时间重叠,则可能会交叉运行。
关于javascript - 链式 Q Promise 序列不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33248484/
一晃五年没写博客了,依旧再C#上耕耘,依旧没有啥建树,现在也不知道.net上还有多少人再使用,在这里分享一些自己觉得写的还算优雅的代码。 对于自己写着完的代码,我特别喜欢链式(来源于jQuer
我正在构建一个吉他和弦查找应用程序。我使用多维数组来表示指板。数组中的每个元素都由具有字符串属性“Note”的 FretSpace 结构表示。为了初始化指板上的音符属性,我传递了要处理的吉他弦的详细信
我在演示代码中使用 setTimeout 函数模拟了 3 个 ajax 调用。我将从一段运行良好的代码开始:所有调用都是并行进行的,我希望所有调用都能成功,否则会出现错误。 var p1 = func
谁能解释一下? a = [2,3,4] b = [5,6,8,9] print(len(a) > 0) print(len(b) > 0) print((len(a) > 0) & len(b) >
我正在处理具有多个子 JSONObject 的 JSONObject。这是我填写内容的方式: myJson.getJSONObject(CAT_NAME).put(VAR_NAME, var)
想象一下这种情况,我有一个需要检查属性的对象。但是,该对象当前可以具有空值。 如何在一个“if”条件下检查这两个条件? 目前,我必须做这样的事情: if (myObject != null) {
我有一个对象集合,称它们为obj。他们有一个 act() 方法。 act() 方法最终会导致 o 上的 event() observable 调用 onComplete。 链接这些的好方法是什么? 即
假设我有一个列表变量 datalist 存储 10,000 个字符串实体。QTableView 只需要显示其中的一些实体。这就是为什么 QTableView 被指定为 QSortFilterProxy
我正在寻找支持链式 MSI 安装的工具(最好不是 InstallShield,而且最好是便宜/免费的)。我有几个小型安装需要能够单独部署,但也需要作为一个组部署,我不想维护多个安装程序。 看起来我需要
在这种情况下,我想迭代集合中除最后 2 个元素之外的所有元素。 假设我采用了一种奇怪的方式,例如 x.Reverse().Skip(2).Reverse()。 每个 LINQ 操作是否会有效地生成一个
对于javascript来说非常陌生,我有两个html数字选择,包括年份,我想将第二个选择与第一个选择链接起来,这样当我在第一个选择中选择年份时(而第二个选择没有选项)首先),第二个选择应包括从所选数
有人可以向我解释一下为什么以下两个链式函数: // returns zero if okay var resetCounter = function (model) { return new Prom
所以我有 2 个 promise 函数。当第一个函数出现错误时,我希望它显示错误消息。当完成或失败时,我希望他们执行一个finally catch all 函数,但由于某种原因它不起作用。我的代码如下
我有一个函数 const func = () => server.insertPatientSurveyQuestionToDataBase(Store.getPatientID(), SurveyN
(async function() { var a,b; function flush(){ return new Promise(res => {
这个问题已经有答案了: Promise chaining: Use result from previous promise in next then callback [duplicate] (1
这可能不是专业正则表达式理解的问题。唯一重要的是因为我正在运行多个链式替换命令,这些命令会影响文本文件中的某些相同文本。我还想象在替换之前,根据分隔符词(需要多次替换)的使用方式对 txt 文件进行分
我正在尝试构建一组类来定义 OSI 堆栈中协议(protocol)的分层属性...从抽象意义上讲,我只需要从父 python 类继承属性,但我需要能够调用整个类链一次...所以,我正在寻找这样的东西.
我正在努力兑现 promise ,到目前为止我偶然发现了这一点: new Promise((resolve, reject) => { setTimeout(() => { r
我试图理解 promise ,我需要链接它们并装饰来自不同端点的对象宽度数据。 例如: 我的 Node-express 应用程序中有这个 //controller.js export const ge
我是一名优秀的程序员,十分优秀!