qq小程序组件加载失败分析

1. 问题

qq小程序(基于uni-app)使用JS分发和组件分发插件后,有些页面会白屏,打开调试器,会看到下面的报错:

意思是找不到这个页面,然后列举了一系列的有效的组件。

这个问题只在qq小程序的真机上出现,在qq小程序开发者工具、微信小程序都没有。

2. 原因

找了一圈原因,最后发现是执行顺序不同导致的原因。qq小程序真机上,并不是先运行Page页面,而是先执行每个组件,或者说校验每个合理的组件,而其他环境,都是先执行Page下的js

Page下的js会加载此分包下的vendor.js,也就是每个页面下的js第一句都是下面的代码:

js 复制代码
require('./common/vendor.js');(global["webpackJsonp"]=global["webpackJsonp"]||[]).push()

这会加载分包中的module,注册一些moduleId。而qq小程序真机环境先执行了组件,此时如果某些moduleId还没注册的话,就会报错。

3. 实验

我们检验一下这个结论,在组件和页面对应的JS中分别打印一句话,看看执行顺序。

在qq小程序真机下:

在qq小程序开发者工具下:

上面的create page对应页面,press switch对应组件,可以看到qq小程序真机与开发者工具,对组件和页面的加载顺序确实不同。

4. 解决

如何解决这个问题呢?既然组件需要这个moduleId,那就提前加载好就可以了。这里写了个插件,自动引入分包所在的vendor

会不会有副作用呢?不会的,这里要了解下webpack运行时原理。vendor.js只是往global["webpackJsonp"]push了一些modulepush方法被hook了,本质是会缓存一些moduleId

另外,那些并非插件移动的组件为什么没问题呢,因为它们和Page下的js一样,第一句都引用了分包中的vendor.js

5. 后记

虽然是个小问题,定位却花了不少时间,因为微信小程序没问题,所以没往执行顺序不同那方面想,期间猜想问题原因可能是moduleId找错了之类的。

相关推荐
陈_杨1 分钟前
鸿蒙APP开发-带你了解单块酷APP参数管理的功能
前端·javascript
moMo2 分钟前
# 从重置样式到 BEM 命名:写一个微信的按钮
前端·css
2301_815645384 分钟前
saas 一面
前端·面经
无风听海8 分钟前
OAuth 2.0 Scope 的使用与设计规划
前端
2501_9160088911 分钟前
全面解析常用Web前端开发工具:编辑器、调试工具、性能分析器与框架
android·前端·ios·小程序·uni-app·编辑器·iphone
暗夜猎手-大魔王14 分钟前
转载--Hermes Agent 08 | Agent 的自我进化:nudge、后台审查与轨迹数据
java·前端·人工智能
IT_陈寒23 分钟前
Redis集群节点迁移把我坑惨了,这个坑你得提前绕开
前端·人工智能·后端
新酱爱学习26 分钟前
手搓 10 个 Skill 踩出来的坑,我做成了一套工程化工具链
前端·人工智能·agent
怕浪猫34 分钟前
Electron 开发实战(八):多媒体处理全解|音视频播放、录屏、FFmpeg 实战
前端·javascript·electron
恋猫de小郭36 分钟前
一个 Linux 调度器优化,让 Android 多耗 20% 的电,传音工程师如何发现问题?
android·前端·ios