1. ホーム
  2. javascript

[解決済み] Babel 6 regeneratorRuntimeが定義されていません。

2022-03-21 05:19:41

質問

Babel 6でゼロからasync/awaitを使おうとしているのですが、以下のような問題が発生します。 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;

async/awaitを使わずに普通に使っても問題なく動作します。何が間違っているのでしょうか?

解決方法は?

babel-polyfill ( 廃止予定 が必要です(Babel 7.4時点)。また、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");

を使用している場合 ウェブパック の最初の値として配置する必要があります。 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