Опитвам се да използвам async, await от нулата на Babel 6, но получавам 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 работи добре. Има ли идеи какво правя погрешно?
babel-polyfill
е задължителен. Трябва да го инсталирате, за да може да работи async/await.
npm i -D babel-core babel-polyfill babel-preset-es2015 babel-preset-stage-0 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" ]
}
.js с 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, трябва да го поставите като първа стойност на масива 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
Освен polyfill използвам babel-plugin-transform-runtime. Плъгинът е описан като:
Екстернализирайте препратките към помощни програми и вградени модули, като автоматично полифилмирате кода си, без да замърсявате глобалите. Какво обаче означава това в действителност? По принцип можете да използвате вградени модули като Promise, Set, Symbol и т.н., както и да използвате всички функции на Babel, които изискват полифилм, безпроблемно, без глобално замърсяване, което го прави изключително подходящ за библиотеки.
Той включва и поддръжка на async/await заедно с други вградени модули на ES 6.
$ npm install --save-dev babel-plugin-transform-runtime
В .babelrc
добавете приставката за изпълнение
{
"plugins": [
["transform-runtime", {
"regenerator": true
}]
]
}
Забележка Ако'използвате babel 7, пакетът е преименуван на @babel/plugin-transform-runtime.
Ако не се нуждаете от всички модули, които предоставя babel-polyfill
, можете просто да посочите babel-regenerator-runtime
в конфигурацията на Webpack:
module.exports = {
entry: ['babel-regenerator-runtime', './test.js'],
// ...
};
Когато използвах webpack-dev-server с HMR, това намали доста броя на файловете, които трябва да се компилират при всяко компилиране. Този модул се инсталира като част от babel-polyfill
, така че ако вече разполагате с него, всичко е наред, в противен случай можете да го инсталирате отделно с npm i -D babel-regenerator-runtime
.