如何用延迟链接函数。我尝试了以下几点:
Promise.resolve()
.then(setKeyframe('keyframe-0'))
.then(delay(3000))
.then(setKeyframe('keyframe-1'))
.then(delay(3000))
.then(setKeyframe('keyframe-2'))
;
function delay(ms) {
return new Promise((resolve, reject) => {
setTimeout(resolve, ms);
});
}
function setKeyframe (name) {
var element = document.getElementsByClassName('animation-container')[0];
element.className = 'animation-container ' + name;
}所有函数似乎都是在彼此之后立即调用的。延迟函数不延迟链。我遗漏了什么?
发布于 2016-04-14 15:43:23
.then()接受一个函数,该函数可能返回或不返回承诺
然而,你却直接兑现了一个承诺。
// Yes
Promise.resolve().then(() => { return new Promise(); });
// No
Promise.resolve().then(new Promise());发布于 2016-04-15 21:51:21
使用没有参数的函数可能更容易发现您的错误:
正确的方法:
Promise.resolve().then(setFirstKeyframe)上面,函数setFirstKeyframe是.then的一个参数,以便以后调用。
错误的方式:
Promise.resolve().then(setFirstKeyframe())在这里,setFirstKeyframe被立即调用(!),其结果(承诺)被传递给then (当then期望一个函数时,它会被忽略)。
对于带有参数的函数,请使用匿名函数:
Promise.resolve().then(function() {
return setFirstKeyframe('keyframe-0');
})这就是es6箭头函数摇滚的地方:
Promise.resolve().then(() => setFirstKeyframe('keyframe-0'))发布于 2016-04-14 15:50:00
这是因为您调用了所有函数,而不是将它们作为处理程序提供。
Promise.resolve('keyframe-0')
.then(setKeyframe)
.then(delay(3000, 'keyframe-1'))
.then(setKeyframe)
.then(delay(3000, 'keyframe-2'))
.then(setKeyframe)
;
function delay(ms, value) {
return function (val) {
return new Promise((resolve, reject) => {
setTimeout(resolve, ms, value !== undefined ? value : val);
});
};
}
function setKeyframe(name) {
var element = document.body;
element.className = 'animation-container ' + name;
}html, body {
height: 100%;
margin: 0;
padding: 0;
}
.keyframe-0 { background: red; }
.keyframe-1 { background: green; }
.keyframe-2 { background: blue; }
https://stackoverflow.com/questions/36627845
复制相似问题