未定义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(自Babel 7.4起已弃用)。您还必须安装它才能使异步/等待工作。

npm i -D babel-core babel-polyfill babel-preset-es2015 babel-preset-stage-0 loader" title="babel-loader">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

以上是 未定义Babel 6 regeneratorRuntime 的全部内容, 来源链接: utcz.com/qa/397623.html

回到顶部