首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ES6承诺:如何使用参数链接函数

ES6承诺:如何使用参数链接函数
EN

Stack Overflow用户
提问于 2016-04-14 15:39:41
回答 3查看 2.5K关注 0票数 2

如何用延迟链接函数。我尝试了以下几点:

代码语言:javascript
复制
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;
}

所有函数似乎都是在彼此之后立即调用的。延迟函数不延迟链。我遗漏了什么?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2016-04-14 15:43:23

.then()接受一个函数,该函数可能返回或不返回承诺

然而,你却直接兑现了一个承诺。

代码语言:javascript
复制
// Yes
Promise.resolve().then(() => { return new Promise(); });

// No
Promise.resolve().then(new Promise());
票数 3
EN

Stack Overflow用户

发布于 2016-04-15 21:51:21

使用没有参数的函数可能更容易发现您的错误:

正确的方法:

代码语言:javascript
复制
Promise.resolve().then(setFirstKeyframe)

上面,函数setFirstKeyframe.then的一个参数,以便以后调用。

错误的方式:

代码语言:javascript
复制
Promise.resolve().then(setFirstKeyframe())

在这里,setFirstKeyframe被立即调用(!),其结果(承诺)被传递给then (当then期望一个函数时,它会被忽略)。

对于带有参数的函数,请使用匿名函数:

代码语言:javascript
复制
Promise.resolve().then(function() {
  return setFirstKeyframe('keyframe-0');
})

这就是es6箭头函数摇滚的地方:

代码语言:javascript
复制
Promise.resolve().then(() => setFirstKeyframe('keyframe-0'))
票数 5
EN

Stack Overflow用户

发布于 2016-04-14 15:50:00

这是因为您调用了所有函数,而不是将它们作为处理程序提供。

代码语言:javascript
复制
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;
}
代码语言:javascript
复制
html, body {
  height: 100%;
  margin: 0;
  padding: 0;
}

.keyframe-0 { background: red; }
.keyframe-1 { background: green; }
.keyframe-2 { background: blue; }

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36627845

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档