JavaScript 未定义Babel 6 regeneratorRuntime
我正在尝试使用异步,在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
是必须的。您还必须安装它才能使异步/等待工作。
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");
如果您使用的是
,则需要将其作为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
以上是 JavaScript 未定义Babel 6 regeneratorRuntime 的全部内容, 来源链接: utcz.com/qa/401069.html