我正在尝试使用异步,在 Babel 6 上从头开始等待,但是我得到的 regeneratorRuntime 尚未定义。
.babelrc 文件
{
"presets": [ "es2015", "stage-0" ]
}
package.json 文件
"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;
正常使用它而不需要异步 / 等待就可以了。有什么想法我做错了吗?
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" ]
}
带有 async / await 的. 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 ,则需要将其作为entry
数组的第一个值放在 webpack 配置文件(通常是webpack.config.js
)中,按照 @Cemen 注释:
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
注意如果您使用的是 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
}]
]
}
Babel 7 用户
我遇到了一些麻烦,因为大多数信息都针对先前的 babel 版本。对于 Babel 7,安装以下两个依赖项:
npm install --save @babel/runtime
npm install --save-dev @babel/plugin-transform-runtime
并且,在. babelrc 中,添加:
{
"presets": ["@babel/preset-env"],
"plugins": [
["@babel/transform-runtime"]
]
}