Taro新建项目使用async报错regeneratorRuntime is not defined
更新:HHH   时间:2023-1-7


当用 Taro 命令 taro init myApp 创建项目的时候,等程序运行结束,进入到 myApp 目录中,执行 npm run dev:weapp 的时候,代码可以正常运行。

但是当我们在代码中用 async/await 的方式写了一些代码之后,就不能正常运行了,报错如下:

VM49:1 thirdScriptError
regeneratorRuntime is not defined
ReferenceError: regeneratorRuntime is not defined

原因就是缺少安装 babel-plugin-transform-runtime 和 babel-runtime 两个依赖。

yarn add babel-plugin-transform-runtime --dev
yarn add babel-runtime

⚠️注意:如果是 Taro v1 版本的话,还需要安装 @tarojs/async-await 这个包。升级到 Taro v2 版本后就不需要这个包了。

安装完成之后,需要修改一下 config/index.js 文件:

plugins: [
    'transform-decorators-legacy',
    'transform-class-properties',
    'transform-object-rest-spread',
+   ['transform-runtime', {
+       "helpers": false,
+       "polyfill": false,
+       "regenerator": true,
+       "moduleName": 'babel-runtime'
+   }]
}

其中前面带有 + 部分是需要添加的内容。

另外,当我们在 Taro中使用 async 的方式写代码时,还需要在开发前配置这些地方请添加链接描述。

再次运行,小程序就不会报错啦!

我的博客:https://www.wanghuiblog.com

返回web开发教程...