DCloud_App_Array
DCloud_App_Array
  • 发布:2019-02-26 17:09
  • 更新:2024-02-18 14:23
  • 阅读:12768219

uni-app运行环境版本和编译器版本不一致的问题

分类:uni-app

HBuilderX1.7.0及以上版本uni-app添加了运行环境版本和编译环境版本的校验机制,当两个版本不一致时会弹出以下提示:

  • “手机端SDK版本”:是指5+Runtime的版本号。云打包提交云端打包时确定的,也就是说生成apk/ipa之后,APP运行环境就不会改变了。离线打包时是你下载的sdk的版本。只有默认真机运行基座、云打包机的引擎是和HBuilderX升级而自动升级的。如果你使用了自定义基座、sdk离线打包,需要手动升级,或者重新用新版制作自定义基座,或者下载最新版sdk。
  • “HBuilderX版本”:如果项目是HBuilderX创建的,则是HBuilderX的版本号,更新HBuilderX会改变;如果是cli创建的项目,即根目录是package.json,那么编译环境版本号是创建cli时生成的,或者上一次执行npm update生成的。不管HBuilderX如何升级,cli项目的编译器并不会跟随HBuilderX升级而升级,需手动升级。

什么时候会出现这种问题?

  • 情况1:HBuilderX版本很老,或cli编译器一直没升级,而云打包服务器已经升级,此时编译环境版本低,而运行环境版本高,就会报错。
  • 情况2:使用老版HBuilderX打包了App后,后来使用新版HBuilderX或新版cli制作了wgt升级包。此时编译环境会高于运行环境,也会报错。
  • 情况3:使用了cli或自定义基座或本地打包,虽然HBuilderX升级了,但这些配套并没有手动升级,也是报错。
  • 情况4:如果HBuilderX版本高于SDK版本,有可能是HBuilderX在升级时出现问题,手机端基座没有升级成功。如果是这种情况,在插件管理里卸载“真机运行插件”,然后重新安装这个插件。

出现问题该怎么办?

  1. 比较简单的就是全部升级,保持HBuilderX、自定义基座、cli项目编译器都是最新版。
  2. wgt升级时遇到这个问题,首先你可以自测,看老的运行引擎和新版编译器编的wgt是否搭配,如果测试有问题,那不能使用wgt升级,请使用整包升级。如果测试正常,可以在manifest.json文件的源码视图中配置忽略这个提醒,在“app-plus”->"compatible" 节点下添加配置 方式如下:
    HBuilderX1.9.0及以上版本新增以下配置避免弹出提示框
    //...  
    "app-plus": {  
        "compatible": {  
            "ignoreVersion": true //true表示忽略版本检查提示框,HBuilderX1.9.0及以上版本支持  
        },  
    //....  
    },  
    //...

    以下方法可针对指定版本避免弹出提示框。

    //...  
    "app-plus": {  
        "compatible": {  
            "runtimeVersion": "1.7.0", //根据实际情况填写  
            "compilerVersion": "1.7.1" //根据实际情况填写  
        },  
    //....  
    },  
    //...
    • "runtimeVersion"字段值表示应用兼容的uni-app运行环境版本号,可以配置多个版本号(使用英文字符,分隔)
    • "compilerVersion"字段值表示编译环境版本号,通常配置当前HBuilderX的版本号或cli编译器版本即可(不可以配置多个)

建议:尽量使用相同的HBuilderX版本制作移动App资源升级包

本地离线打包请及时更新到与HBuilderX版本相对应的App离线打包SDK

cli项目请及时npm update 更新到最新cli,如需指定cli版请参考:修改依赖为指定版本

注意
平台并不知道使用者是正常用户还是开发者。
但开发者在发布给最终用户之前,请务必先自行测试好。
目前出这个问题的,大多是因为制作wgt升级包造成的。
请使用wgt升级的开发者的,务必在测试环境上先测试好了再发布wgt。
在HBuilderX 1.9版里,已经在制作wgt时强调提示了这个信息。

30 关注 分享
Trust DCloud_UNI_HT 萌龙 DCloud_HB_WDL 5***@qq.com ZFPartric 一杯茶 独家记忆112 强Love丹 刘桂珍 世博 阳一 许永斌 诱惑 土哥 王杰打豆豆 小黄敏 Storm1171 1***@qq.com 实力青年 Adenaka 徐必庆 p***@163.com 王虎林 8***@qq.com 1***@qq.com a***@gmail.com 付宝永 r***@gmail.com 董硕

要回复文章请先登录注册

Gavin2020

Gavin2020

回复 y***@163.com :
确实
2023-04-06 16:26
2***@qq.com

2***@qq.com

是真的不敢升级了以后,热更新在苹果上失效 搞了半天的回退版本重新打包,这种以后打包之前还得看看版本/基座是否合适呢。好烦啊
2023-02-27 17:27
y***@163.com

y***@163.com

这就是妥妥的懒政,摆烂了嗷,本来用uniapp的开发者都是些做小项目的小公司,一个前端包干那种,现在这么一搞,等于只要云端环境和本地环境不一样就要更新,考虑过每次更新以后还会出现各种版本导致的问题吗,还需要去debug,如果一个人维护多个项目,那真有的受的。
2023-02-17 14:46
tuonioooo

tuonioooo

为什么升级会导致 这么多的问题 是编译器的问题 还是云端缓存在作怪
2023-02-17 10:57
l***@qq.com

l***@qq.com

升个球,一升级编译器整个项目都寄了。
2023-02-17 10:38
西城东哥

西城东哥

回复 1***@qq.com :
"app-plus" : {
"compatible" : {
"ignoreVersion" : true //true表示忽略版本检查提示框,HBuilderX1.9.0及以上版本支持
}
}
2023-02-15 10:41
西城东哥

西城东哥

回复 阿怪1874 :
"app-plus" : {
"compatible" : {
"ignoreVersion" : true //true表示忽略版本检查提示框,HBuilderX1.9.0及以上版本支持
}
}
2023-02-15 10:41
onion一只洋葱

onion一只洋葱

回复 阿怪1874 :
版本多了维护起来成本变高,官方不愿意搞
2023-02-15 10:29
i***@163.com

i***@163.com

回复 1***@qq.com :
把原来的删除,重新下载了HBuilderX 问题解决
2023-01-06 14:02
DCloud_App_Array

DCloud_App_Array (作者)

回复 i***@163.com :
请提供下appid我们查下打包日志。出现这种情况可能存在两种可能:
1. 项目是cli命令创建的,此时需要更新cli版本,参考这里:https://uniapp.dcloud.net.cn/quickstart-cli.html#cliversion
2. HBuilderX升级不完整,菜单“工具” -> "插件安装",在已安装插件列表中查看“App真机运行”的版本号是否与HBuilderX版本一致,如果不一致可以卸载此插件重新安装。如果还有问题可以尝试重新安装HBuilderX。
2023-01-05 12:30