javascript - 调用具有默认参数的异步函数作为参数检查同步处理的函数?

标签 javascript asynchronous babeljs ecmascript-2017

我在调用时使用异步函数和默认参数进行评估。

使用默认参数,我使用一个函数来检查是否提供了值。

function mandatory(paramName) {
    throw new Error(`Missing parameter: ${paramName}`)
}

async function foo({ a, b = mandatory('b') }) {
    return Promise.resolve(b)
}

// uses chai.assert and chai-as-promised
describe('foo', () => {
    it('should return a rejected promise', async () => {
        const promise = foo({ a: 'hi' })
        assert.isRejected(promise, /Error: Missing parameter: b/)
    })
})

此测试因错误而失败:

Error: Missing parameter: b

因为这个异常是在异步流程之外抛出的,你可以在这里看到:

var foo = function () {
    var _ref = _asyncToGenerator(regeneratorRuntime.mark(function _callee(_ref2) {
        var _ref2$a = _ref2.a,
            a = _ref2$a === undefined ? 'a' : _ref2$a,
            _ref2$b = _ref2.b,
            b = _ref2$b === undefined ? mandatory('b') : _ref2$b;
        return regeneratorRuntime.wrap(function _callee$(_context) {
            while (1) {
                switch (_context.prev = _context.next) {
                    case 0:
                        return _context.abrupt('return', Promise.resolve(b));

                    case 1:
                    case 'end':
                        return _context.stop();
                }
           }
       }, _callee, this);
    }));

    return function foo(_x) {
        return _ref.apply(this, arguments);
    };
}();

function _asyncToGenerator(fn) { 
    return function () { 
         var gen = fn.apply(this, arguments); 
         return new Promise(function (resolve, reject) { 
             function step(key, arg) { 
                 try { 
                     var info = gen[key](arg); 
                     var value = info.value; 
                 } catch (error) { 
                     reject(error); return; 
                 } 
                 if (info.done) { 
                     resolve(value); 
                 } else { 
                     return Promise.resolve(value).then(function (value) { 
                         step("next", value); 
                     }, 
                     function (err) { 
                         step("throw", err); 
                     }); 
                 } 
             } 
             return step("next"); 
         }); 
     }; 
 }

我的问题:这是根据规范还是根据实现?我希望 promise 被拒绝,而不是被抛出。

最佳答案

这可能是 Babel 中的一个错误,因为在最新的 Chrome(它支持带有标志的异步函数)和 Firefox 52 中,这段代码按预期工作(即 promise 被拒绝):

function mandatory(paramName) {
  throw new Error(`Missing parameter: ${paramName}`)
}

async function foo({ a, b = mandatory('b') }) {
  return Promise.resolve(b)
}

foo({a: 'hi'}).catch(error => console.log('rejected')) // logs 'rejected'

关于javascript - 调用具有默认参数的异步函数作为参数检查同步处理的函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40934091/

相关文章:

javascript - 如何在 Canvas 顶部的图像上获得围绕鼠标光标的悬停效果?

php - 使用 PHP 将录制的音频文件发送到 Web 服务器

android - 在 Android 应用程序中实现此行为的最佳策略?

node.js - 在 Node.js 中动态导入 webpack

javascript - 滚动时如何使网站捕捉到下一个 anchor ?

mysql - Slick 中的线程安全

javascript - NodeJS : Append file inside a callback function

javascript - AST 到 JS 的代码转换器

javascript - react 错误: unknown word when using webpack

javascript - 在我的 href 中添加一些内容