DCloud_heavensoft
DCloud_heavensoft
  • 发布:2020-02-26 07:24
  • 更新:2022-09-29 13:06
  • 阅读:23523

公告:App老版“自定义组件编译模式”将于2020年4月的HBuilderX 2.7版本下线

分类:uni-app
v3

从2018年至今,uni-app的编译器历经了3代发展:非自定义组件模式、自定义组件模式、v3编译器。

在经历了3次重写编译器后,v3的出现,代表着uni-app进入成熟期。

关于v3编译器的新特性介绍,详见:https://ask.dcloud.net.cn/article/36599

v3编译器凝集了DCloud团队在2年的uni-app开发历程中的所有经验和教训,吸收了数百万开发者在实践中的反馈,在架构层面堪称完美。

在可预见的将来,DCloud不会立项开发v4编译器,而是将在v3的架构上持续迭代完善。

目前“非自定义组件模式”已经下线,“自定义组件模式”也走到生命周期的尾声。

为了集中精力、减少包体积,2020年4月发布的HBuilderX 2.7版本起,及对应的App SDK包,将不再提供“自定义组件模式”。(uni小程序sdk本身也仅支持v3)。

届时新版uni-app里将没有各种编译器的概念,包括v3的概念也没有,manifest里会取消所有编译器设置,项目默认运行在v3编译器下。对于新的开发者,他将无需理解这些编译器名称、区别。

与非自定义组件升级自定义组件不同,自定义组件升级v3正常没有需要改代码的地方,在设计上是完全向下兼容的。

如果你的App之前正常,但勾选v3编译器后异常,有2种可能:

  1. v3编译器有bug,请在社区单独发帖,提供重现方式。DCloud会优先解决,保障v3的向下兼容性。
  2. 你的应用之前使用了不推荐的写法,比如一些hack方式。此时需要你更正为正确的写法。如果正常写法无法满足你的需求,请发帖告知我们。

因v3的升级是app-vue端的,如果你之前的应用不涉及App端,或者App是纯nvue的,那么不受“自定义组件模式”下线的影响。

详细的过渡调整方案如下:

  • HBuilderX 2.6.9开始,manifest.json的默认值从非v3调整为v3,即不写"compilerVersion" : 3,,也是v3编译模式。如果需要降级为非v3,请在manifest可视化界面-App其他常用配置 中去掉v3编译器的勾选。

  • HBuilderX 2.7开始,将移除非v3编译器,只保留v3编译模式。如果开发者使用老版HBuilderX,也仍然可使用非v3编译器。本地打包可以通过使用老版的sdk来继续使用非v3。然后云打包将于5月底不再支持非v3的打包。

不管HBuilderX新版怎么调整,开发者已经发布在线上的App不会受到影响。

最后,再次强调,官方之所以敢于下线老版,是因为这2个编译器的差异没有那么大。正常老应用应该都是可以兼容的。如果在发布2.7版本前,v3的向下兼容性问题没有修复完毕的话,是不会强制下线的。

目前已知的主要问题就是subnvue的postmessage通信写法不再支持,建议使用新的页面通信方式https://uniapp.dcloud.io/collocation/frame/communication,更新常见问题排查:https://ask.dcloud.net.cn/article/37342

另,最新的HBuilderX 修复了很多v3的bug,如果要报新bug,请体验新版后再报。

注意:我们强烈建议开发者尽快升级v3版本,因为后续新增功能仅支持v3版本,非v3版本将不再维护。如果您坚持使用老的编译器,有两个方案:

  1. 离线打包
  2. 使用HBuilderX 2.6.16 版(参考https://ask.dcloud.net.cn/article/37302下载历史版本),该版本将继续支持云端打包,其它老的HBuilderX版本将不再支持云端打包。注意,2.6.16版目前仅支持非v3打包,如果是v3版,请正常升级最新HBuilderX。
5 关注 分享
y***@telsafe.com.cn 5***@qq.com Iain 退堂鼓选手 上风下云

要回复文章请先登录注册

睡着就睡着了

睡着就睡着了

更新后跳转到某些页面报错:JSON Parse error: Unrecognized token '%' ,自定义编译模式没有这个问题
2020-03-18 15:06
3***@qq.com

3***@qq.com

老版本已上线的mui h5+开发的受影响吗
2020-03-18 14:53
DCloud_UNI_GSQ

DCloud_UNI_GSQ

回复 青椒茄子 :
不是问题,v3模式和h5更加接近,遵循vue的生命周期,此时子组件还未创建
2020-03-17 19:30
DCloud_UNI_GSQ

DCloud_UNI_GSQ

回复 5***@qq.com :
生成资源升级包的HBuilderX需要和当初生成整包使用的HBuilderX版本相同。
2020-03-17 16:39
青椒茄子

青椒茄子

UniApp使用V3编译器,在onload使用this.$refs.x报错或提示找不到组件,切换为自定义组件模式无此问题
2020-03-17 15:11
l***@qq.com

l***@qq.com

HBuilderX每次升级过后都得把所有功能测试一遍,太累了。现在根本不敢升级,有时候一个小版本升级也会带来很多问题,这次V3强制升级不知道会带来多少问题。
2020-03-17 10:19
阁楼庭院

阁楼庭院

哎,真难受,非组件模式换组件模式就考虑了好久才换好,这马上又来强制v3,v3刚发行时试着切换了下,各种问题,又换回去组件模式了,这次倒好,直接强制你更新,比3Q大战还艰难。。。。
2020-03-17 09:10
拓荒

拓荒

看社区和官方的更新日志感觉v3或者新的编译模式还有不少bug啊,真不敢轻易升级。
2020-03-16 16:38
2***@qq.com

2***@qq.com

回复 2***@qq.com :
"正常老应用应该都是可以兼容的" 这不是一个专业的公司该有的严谨态度,每一次强制升级都对已上线的应用充满了风险挑战
2020-03-16 14:22
2***@qq.com

2***@qq.com

uniapp也要走angular的老路了吗?距离上次强制更新自定义组件才不过几个月,公司的精力更多还是在业务上面,做事情留点余地不行吗?谁提的这个糟糕的主意,刚升级了组件模式又要换v3,对这种强制升级的做法强烈不满
2020-03-16 14:19