Babel 6 で最初から async/await を使用しようとしていますが、regeneratorRuntime
is not defined というエラーが発生します。
.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;
async/await なしで通常通り使用すると問題なく動作します。何が間違っているのか、何かアイデアはありますか?
ベストアンサー1
babel-polyfill
(非推奨Babel 7.4 以降では、async/await が必要です。async/await を動作させるには、これもインストールする必要があります。
npm i -D babel-core babel-polyfill babel-preset-es2015 babel-preset-stage-0 babel-loader
パッケージ.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を使用している場合は、@Cemen のコメントに従って、entry
webpack 構成ファイル内の配列の最初の値 (通常は ) としてこれを配置する必要があります。webpack.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