uni-app HBuilder 升级到 4.36 后 启动H5项目报错

发布于 1周前 作者 vueper 来自 Uni-App

uni-app HBuilder 升级到 4.36 后 启动H5项目报错

开发环境 版本号 项目创建方式
Windows win11 HBuilderX

操作步骤:

  • 启动H5报错

预期结果:

  • 找到问题,4.29没有这个问题。

实际结果:

  • 启动H5报错

bug描述:

项目创建的是uniapp项目,使用了VUE3,启动web h5后,就会一直报这个错误:

main.js:22 TypeError: Cannot read properties of undefined (reading '$page')
at new ServiceMediaQueryObserver (uni-h5.es.js:4690:30)
at uni-h5.es.js:4726:10
at Module.createMediaQueryObserver (uni-h5.es.js:3070:15)
at Proxy.mounted (uni-match-media.vue:53:30)

Unhandled error during execution of mounted hook
at <UniMatchMedia>
at <View>
at <View>
at <Top>
at <Layout>
at <App>

适配组件还出现了问题,pages 中使用了,top left 框架组件,还有match-media这个组件。

退回到 HBuilder 4.29 版本,就不会有这个问题,请帮忙核实,谢谢。


4 回复

目前的解决办法,只能回退到 HBuilder 4.29 版本使用。


你好,可以提供一下可以复现的项目吗?

您好,我上传了一个test.zip附件,请查看一下,新创建的一个项目,用 4.36 运行,可以看到错误。

针对您提到的uni-app HBuilder升级到4.36版本后启动H5项目报错的问题,这通常可能与版本更新引入的兼容性问题、配置变动或依赖库的更新有关。由于您要求不给出建议而直接提供代码案例,我将尝试通过展示一些常见的排查和修复步骤中的代码片段来帮助您定位问题。请注意,以下代码片段并非完整的解决方案,而是用于引导您检查可能的问题区域。

1. 检查manifest.json配置

首先,确保manifest.json中的配置与新版HBuilder X兼容。特别是H5相关的配置,如h5节点下的路径、权限等设置。

{
  "mp-weixin": {},
  "h5": {
    "title": "uni-app",
    "domain": [
      "yourdomain.com"
    ],
    "router": {
      "mode": "history",
      "base": "/"
    },
    // 其他配置...
  }
}

2. 检查vue.config.jswebpack.config.js

如果项目使用了自定义的webpack配置,检查是否有与新版HBuilder X不兼容的插件或loader配置。

// vue.config.js 示例
module.exports = {
  configureWebpack: {
    resolve: {
      alias: {
        '@': path.resolve(__dirname, 'src')
      }
    },
    // 确保loader和plugin版本与HBuilder X 4.36兼容
  }
};

3. 检查依赖库版本

有时候,项目依赖的第三方库可能还没有兼容新版本的开发工具。运行npm outdated查看可升级的包,并考虑升级。

npm outdated
npm update

4. 查看控制台输出和日志文件

启动项目时,仔细查看控制台输出的错误信息,这些信息通常会指向具体的错误原因。如果是编译错误,查看dist/build/log目录下的日志文件可能提供更多线索。

5. 清理缓存和重新安装依赖

有时候,清理项目缓存和重新安装node_modules可以解决一些莫名其妙的问题。

rm -rf node_modules
rm package-lock.json # 或 yarn.lock
npm install # 或 yarn install

由于无法直接复现您的具体错误,以上步骤更多是作为排查方向的指引。如果问题依旧存在,建议查阅DCloud官方论坛或GitHub仓库的issue页面,看看是否有其他开发者遇到并解决了类似的问题。希望这些信息对您有所帮助!

回到顶部