我必须通过API设置一些东西。重要的是不同的功能是在彼此之后执行的。所有列出的函数都返回一个适当的承诺。
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))
之类的东西,但您可能知道这是行不通的。
还有别的办法吗?
发布于 2017-03-09 14:25:17
你可以把它写成
a.then(b.bind(null, listName, analyticsConfig._fieldConfig))
或者,如果您使用巴贝尔来传输代码,或者是针对节点>v4的版本,则可以这样做。
a.then(() => b(listName, analyticsConfig._fieldConfig))
发布于 2017-03-09 14:23:23
只有当b
返回一个返回承诺的函数时,这才会起作用。您必须始终将一个函数作为回调传递给then
,这是无法避免的。然而,有许多方法来构建一个。
撇开部分应用程序(包括bind
或其他应用程序)、运行和诸如此类的东西不谈,您最好选择更好的语法是ES8 async
/await
(async function() {
await a(analyticsConfig._listConfig);
await b(listName, analyticsConfig._fieldConfig);
await c(listName);
await d(analyticsConfig._roleConfig);
})();
或ES6箭头函数:
a(analyticsConfig._listConfig)
.then(() => b(listName, analyticsConfig._fieldConfig))
.then(() => c(listName))
.then(() => d(analyticsConfig._roleConfig))
发布于 2017-03-09 14:25:34
你可以把它绑起来:
a.then(b.bind(context,listName,analyticsConfig._fieldConfig))
但是,一定要将预期的上下文绑定到它。
根据医生们的说法:
bind()
方法创建一个新函数,当调用该函数时,它的this关键字设置为提供的值,在调用新函数时,在任何提供的参数之前都有给定的参数序列。
https://stackoverflow.com/questions/42697739
复制相似问题