首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >JS承诺:控制流程

JS承诺:控制流程
EN

Stack Overflow用户
提问于 2017-03-09 14:20:21
回答 4查看 382关注 0票数 1

我必须通过API设置一些东西。重要的是不同的功能是在彼此之后执行的。所有列出的函数都返回一个适当的承诺。

代码语言:javascript
运行
复制
a(analyticsConfig._listConfig)
    .then(function() {
        return b(listName, analyticsConfig._fieldConfig);
    })
    .then(function() {
        return c(listName)
    })
    .then(function() {
        return d(analyticsConfig._roleConfig);
    })

我想使用类似a.then(b(listName, analyticsConfig._fieldConfig))之类的东西,但您可能知道这是行不通的。

还有别的办法吗?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2017-03-09 14:25:17

你可以把它写成

代码语言:javascript
运行
复制
a.then(b.bind(null, listName, analyticsConfig._fieldConfig))

或者,如果您使用巴贝尔来传输代码,或者是针对节点>v4的版本,则可以这样做。

代码语言:javascript
运行
复制
a.then(() => b(listName, analyticsConfig._fieldConfig))
票数 2
EN

Stack Overflow用户

发布于 2017-03-09 14:23:23

只有当b返回一个返回承诺的函数时,这才会起作用。您必须始终将一个函数作为回调传递给then,这是无法避免的。然而,有许多方法来构建一个。

撇开部分应用程序(包括bind或其他应用程序)、运行和诸如此类的东西不谈,您最好选择更好的语法是ES8 async/await

代码语言:javascript
运行
复制
(async function() {
    await a(analyticsConfig._listConfig);
    await b(listName, analyticsConfig._fieldConfig);
    await c(listName);
    await d(analyticsConfig._roleConfig);
})();

或ES6箭头函数:

代码语言:javascript
运行
复制
a(analyticsConfig._listConfig)
.then(() => b(listName, analyticsConfig._fieldConfig))
.then(() => c(listName))
.then(() => d(analyticsConfig._roleConfig))
票数 4
EN

Stack Overflow用户

发布于 2017-03-09 14:25:34

你可以把它绑起来:

代码语言:javascript
运行
复制
a.then(b.bind(context,listName,analyticsConfig._fieldConfig))

但是,一定要将预期的上下文绑定到它。

根据医生们的说法:

bind()方法创建一个新函数,当调用该函数时,它的this关键字设置为提供的值,在调用新函数时,在任何提供的参数之前都有给定的参数序列。

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

https://stackoverflow.com/questions/42697739

复制
相关文章

相似问题

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