ホームページ > ウェブフロントエンド > jsチュートリアル > Babel 6 で Async/Await を使用すると「regeneratorRuntime が定義されていません」というメッセージが表示されるのはなぜですか?

Babel 6 で Async/Await を使用すると「regeneratorRuntime が定義されていません」というメッセージが表示されるのはなぜですか?

Susan Sarandon
リリース: 2024-12-08 17:38:12
オリジナル
141 人が閲覧しました

Why Am I Getting

「Babel 6 regeneratorRuntime が定義されていません」の説明

Babel 6 で async/await を実装すると、「regeneratorRuntime が定義されていません」エラーが発生する一般的に起こります。この問題を修正するには、さらに babel-polyfill をインストールしてインクルードする必要があります。

Babel 依存関係のインストール

async/await を使用するには、次の依存関係をインストールします。

npm i -D babel-core babel-polyfill babel-preset-es2015 babel-preset-stage-0 babel-loader
ログイン後にコピー

更新中package.json

「devDependency」に以下を追加します:

"babel-polyfill": "^6.0.16"
ログイン後にコピー

Maintaining .babelrc

設定はそのままにしておきます。

{
  "presets": [ "es2015", "stage-0" ]
}
ログイン後にコピー

セットアップAsync/await**

コード内で async/await を有効にします:

"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構成

webpack を使用している場合は、babel-polyfill が最初のエントリであることを確認してください。

module.exports = {
  entry: ['babel-polyfill', './test.js'],

  output: {
    filename: 'bundle.js'       
  },

  module: {
    loaders: [
      { test: /\.jsx?$/, loader: 'babel', }
    ]
  }
};
ログイン後にコピー

Babel を使用したテスト

でテストを実行Babel を使用:

mocha --compilers js:babel-core/register --require babel-polyfill
ログイン後にコピー

以上がBabel 6 で Async/Await を使用すると「regeneratorRuntime が定義されていません」というメッセージが表示されるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート