Babel 6 再生器未定义运行时间

2022-08-29 22:26:09

我试图在 Babel 6 上从头开始使用 async/await,但我得到的是没有定义的。regeneratorRuntime

.babelrc 文件

{
    "presets": [ "es2015", "stage-0" ]
}

package.json file

"devDependencies": {
    "babel-core": "^6.0.20",
    "babel-preset-es2015": "^6.0.15",
    "babel-preset-stage-0": "^6.0.15"
}

.js文件

"use strict";
async function foo() {
  await bar();
}
function bar() { }
exports.default = foo;

在没有异步/等待的情况下正常使用它工作正常。任何想法我做错了什么?


答案 1

babel-polyfill (自 Babel 7.4 起已弃用)是必需的。您还必须安装它才能使异步/等待工作。

npm i -D babel-core babel-polyfill babel-preset-es2015 babel-preset-stage-0 babel-loader

package.json

"devDependencies": {
  "babel-core": "^6.0.20",
  "babel-polyfill": "^6.0.16",
  "babel-preset-es2015": "^6.0.15",
  "babel-preset-stage-0": "^6.0.15"
}

.babelrc

{
  "presets": [ "es2015", "stage-0" ]
}

使用异步/等待.js(示例代码)

"use strict";

export default async function foo() {
  var s = await bar();
  console.log(s);
}

function bar() {
  return "bar";
}

在启动文件中

require("babel-core/register");
require("babel-polyfill");

如果您使用的是 webpack,则需要将其作为数组的第一个值放在 webpack 配置文件中(通常),如 @Cemen 注释所示:entrywebpack.config.js

module.exports = {
  entry: ['babel-polyfill', './test.js'],

  output: {
    filename: 'bundle.js'       
  },

  module: {
    loaders: [
      { test: /\.jsx?$/, loader: 'babel', }
    ]
  }
};

如果你想用 babel 运行测试,那么使用:

mocha --compilers js:babel-core/register --require babel-polyfill

答案 2

注意如果您使用的是 babel 7,则该包已重命名为 @babel/plugin-transform-runtime

除了 polyfill 之外,我还使用 babel-plugin-transform-runtime。该插件描述为:

外部化对帮助程序和内置程序的引用,自动聚合填充代码,而不会污染全局变量。这实际上意味着什么呢?基本上,您可以使用诸如Promise,Set,Symbol等内置功能,也可以使用所有需要polyfill无缝填充的Babel功能,而不会造成全局污染,使其非常适合库。

它还包括对异步/等待以及ES 6的其他内置功能的支持。

$ npm install --save-dev babel-plugin-transform-runtime

在 中,添加运行时插件.babelrc

{
  "plugins": [
    ["transform-runtime", {
      "regenerator": true
    }]
  ]
}