>웹 프론트엔드 >JS 튜토리얼 >Async/Await를 사용하는 Babel 6의 \'regeneratorRuntime이 정의되지 않았습니다\' 오류를 수정하는 방법은 무엇입니까?

Async/Await를 사용하는 Babel 6의 \'regeneratorRuntime이 정의되지 않았습니다\' 오류를 수정하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-03 08:46:09364검색

How to Fix the

Babel 6 Async/Await의 "regeneratorRuntime이 정의되지 않았습니다" 오류 해결

Babel 6에서 async/await 기능을 구현하려고 할 때, 개발자는 "regeneratorRuntime이 정의되지 않았습니다" 오류가 발생할 수 있습니다. 이는 Babel 최신 버전과 달리 async/await 지원을 위해서는 Babel 6의 babel-polyfill 패키지가 필요하기 때문입니다.

해결책:

  1. 설치 babel-polyfill:

    npm i -D babel-polyfill
  2. package.json 업데이트:

    "devDependencies": {
      "babel-polyfill": "^6.0.16",
    }
  3. 웹팩 구성 수정(경우 해당):
    webpack.config.js에서 babel-polyfill이 항목 배열의 첫 번째 항목인지 확인하세요.

    module.exports = {
      entry: ['babel-polyfill', './test.js'],
      ...
    };
  4. babel 설정 -시작 시 폴리필 및 바벨 코어 파일:

    require("babel-core/register");
    require("babel-polyfill");

예제 코드:

"use strict";

export default async function foo() {
  var s = await bar();
  console.log(s);
}

function bar() {
  return "bar";
}

Babel로 테스트 실행:

Babel로 테스트를 실행할 때 다음을 사용하세요. 명령:

mocha --compilers js:babel-core/register --require babel-polyfill

위 내용은 Async/Await를 사용하는 Babel 6의 \'regeneratorRuntime이 정의되지 않았습니다\' 오류를 수정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.