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

公告: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 退堂鼓选手 上风下云

要回复文章请先登录注册

DCloud_heavensoft

DCloud_heavensoft (作者)

回复 wppeng :
不应该调样式,渲染引擎没动。有其他问题,定位到后单独报
2020-03-21 16:19
wppeng

wppeng

回复 Javin :
说的很对,换了v3以前写的样式出问题了,还要一个个调整样式
2020-03-21 16:00
DCloud_heavensoft

DCloud_heavensoft (作者)

回复 Javin :
升级到2.6.6再试
2020-03-20 07:03
Javin

Javin

回复 DCloud_heavensoft :
还有有时候bug并不是我的代码的问题,而是我使用的别人的第三方代码,比如我现在使用某个rsa的加密库升级v3以后就bug了,我没办法修复这个问题,只能找原作者,作者目前也解决不了这个问题,诸如此类的问题就会很尴尬。
2020-03-19 22:45
Javin

Javin

回复 DCloud_heavensoft :
1、v3变快了,对于别人不好说对于我这个强大无关痛痒(仅代表个人)2、大家追求速度可以用uniapp(我之前说话不严谨),这个前提是h5端或小程序端,因为uniapp的实现原理和某些框架是不能比的(现在硬件配置都很高一般的应用对于用户根本体现不出来这个差异所以我认为这不是uniapp的劣势反倒是uniapp的开发便捷度要好得多大家还是图个方便)3、我现在还在开发期所以很多bug没办法现在找到反馈只能用老版本先开发,毕竟开发工作已经很多了,怕是等开发完成以后升级v3编译还是一对bug(至少现在是),然后给官方提bug,官方修复bug这段期间我等于被卡在了中间上不去下不来。
2020-03-19 22:29
s***@outlook.com

s***@outlook.com

这也太要命了
2020-03-19 22:13
DCloud_heavensoft

DCloud_heavensoft (作者)

回复 Javin :
1、v3不止变快了,功能也更强了;2、大家追求速度,为什么不能用uni-app?这话很扯;3、官方会保持稳定性,如果4月1日前v3仍有不兼容bug,官方会推迟下线老版
2020-03-19 21:49
Javin

Javin

之前的软件换了v3各种问题一言难尽,要总结都是什么问题要把代码抽离出来一个个测试,写了70多个页面测试抽离这个时间和精力可是很要命的。我现在没精力一个个bug找,上次升级自定义组建项目还没这么多东西找bug花费了一番精力。现在项目差不多成型了这倒好强制淘汰!不是不想升是现在是在没办法升!不得不思考之后的项目是否还使用DCloud的产品。用的好好的干嘛天天搞事情要升级引擎先搞个非稳定版项目让大家侧着等大部分问题都解决了再升级也不迟。感觉现在DCloud的项目没有原则心血来潮想什么做什么,换句话说升级这么个破玩意无非就是主要体现在启动速度快那么一点点,但是对开发者来说这点启动速度的提升几乎没有太大意义,如果大家要追求速度没人会用uniapp。对于这个产品其稳定性和生态是至关重要的。uniapp的口碑变差有越来越多的开发者表示弃坑的趋势需要注意。
2020-03-19 21:45
DCloud_heavensoft

DCloud_heavensoft (作者)

回复 睡着就睡着了 :
单开贴,详细说明
2020-03-19 03:59
DCloud_heavensoft

DCloud_heavensoft (作者)

回复 3***@qq.com :
这是uni-app,其他不受影响
2020-03-19 03:57