patternjavascriptCritical
Babel 6 regeneratorRuntime is not defined
Viewed 0 times
regeneratorruntimedefinednotbabel
Problem
I'm trying to use async/await from scratch on Babel 6, but I'm getting
.babelrc file
package.json file
.js file
Using it normally without the async/await works just fine. Any ideas what I'm doing wrong?
regeneratorRuntime is not defined..babelrc file
{
"presets": [ "es2015", "stage-0" ]
}package.json file
"devDependencies": {
"babel-core": "^6.0.20",
"babel-preset-es2015": "^6.0.15",
"babel-preset-stage-0": "^6.0.15"
}.js file
"use strict";
async function foo() {
await bar();
}
function bar() { }
exports.default = foo;Using it normally without the async/await works just fine. Any ideas what I'm doing wrong?
Solution
babel-polyfill (deprecated as of Babel 7.4) is required. You must also install it in order to get async/await working.npm i -D babel-core babel-polyfill babel-preset-es2015 babel-preset-stage-0 babel-loaderpackage.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 with async/await (sample code)
"use strict";
export default async function foo() {
var s = await bar();
console.log(s);
}
function bar() {
return "bar";
}In the startup file
require("babel-core/register");
require("babel-polyfill");If you are using webpack you need to put it as the first value of your
entry array in your webpack configuration file (usually webpack.config.js), as per @Cemen comment:module.exports = {
entry: ['babel-polyfill', './test.js'],
output: {
filename: 'bundle.js'
},
module: {
loaders: [
{ test: /\.jsx?$/, loader: 'babel', }
]
}
};If you want to run tests with babel then use:
mocha --compilers js:babel-core/register --require babel-polyfillCode Snippets
npm i -D babel-core babel-polyfill babel-preset-es2015 babel-preset-stage-0 babel-loader"devDependencies": {
"babel-core": "^6.0.20",
"babel-polyfill": "^6.0.16",
"babel-preset-es2015": "^6.0.15",
"babel-preset-stage-0": "^6.0.15"
}{
"presets": [ "es2015", "stage-0" ]
}"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");Context
Stack Overflow Q#33527653, score: 757
Revisions (0)
No revisions yet.