0

我正在尝试使用 node js promisify 将回调转换为 promise inoreder 以在异步回调函数上使用 await。

我尝试了不同的方法来传递参数并放置记录器

const {promisify} = require('util');
const callbackFn = (firstName, callback) => {
  setTimeout(() => {
    console.log("1");
    if (!firstName)  callback(new Error('no first name passed in!'),null)

    const fullName = `${firstName} IBM`

    callback(null,fullName)
  }, 2000)
}

async function useAwaitEx(){
  try {
    var calbbackfnpromisfied = promisify(callbackFn);
    console.log("3");
    var result = await calbbackfnpromisfied('mayank',  console.log);
    console.log("2");

   console.log("result"+result)
  }catch (error) {
    console.log("error"+error);
  }
}
useAwaitEx();

我期望输出为 3 1 null 'mayank IBM' 2 null 'mayank IBM'

我得到的输出为 3 1 null 'mayank IBM'

4

1 回答 1

1

我认为一个非常小的变化应该可以解决这个问题。

如果我们想将 console.log 作为参数传递,我们需要在 callbackFn 函数中单独声明它。

这里的关键点是我们不应该在调用时将最后一个回调传递给promisified 函数,这将由我们处理。

我们不会准确记录您希望的内容,因为结果不会为空。

我们将记录:

3
1
null 'mayank IBM' 
2
result: mayank IBM

更新代码:

const {promisify} = require('util');
const callbackFn = (firstName, logCallback, callback) => {

setTimeout(() => {
    console.log("1");
    if (!firstName)  callback(new Error('no first name passed in!'),null)

    const fullName = `${firstName} IBM`

    logCallback(null,fullName)
    callback(null,fullName)

}, 2000)
}

async function useAwaitEx(){
try {
    var calbbackfnpromisfied = promisify(callbackFn);
    console.log("3");
    var result = await calbbackfnpromisfied('mayank', console.log);
    console.log("2");
    console.log("result:", result)

// console.log("result"+result)
}catch (error) {
    console.log("error"+error);
}
}
useAwaitEx();
于 2019-08-14T12:30:27.710 回答