regeneratorRuntime是webpack打包生成的全局辅助函数,由babel生成,用于兼容async/await的语法。
regeneratorRuntime is not defined这个错误显然是未能正确配置babel。
正确的做法需要添加以下的插件和配置:
# 这个包中包含了regeneratorRuntime,运行时需要
npm install --save @babel/runtime# 这个插件会在需要regeneratorRuntime的地方自动require导包,编译时需要
npm install --save-dev @babel/plugin-transform-runtime# 更多参考这里
https://babeljs.io/docs/en/babel-plugin-transform-runtime
接着改一下babel的配置文件
{
"presets": [
"@babel/preset-env"
],
"plugins": [
[
"@babel/plugin-transform-runtime"
]
]
}
这样再次尝试打包即可。
值得注意的是,如果你是node.js的运行环境,由于node.js已经支持的async/await,固无需配置。但如果你用了比如vue ssr之类的,也就是仍旧使用了webpack打包,并有node.js运行,可能需要将其排除掉,或者根本不使用babel-loader。详见https://github.com/vuejs/vue/issues/5559