微信小程序兼容&性能测试方法

本文为微信小程序兼容、性能测试方法介绍。

兼容

操作系统兼容

由于小程序依赖微信客户端本身,因此理论上来说只要微信客户端兼容的小程序应该都可以兼容,这里推荐覆盖Android和iOS主流版本系统即可,参考如下:


Android操作系统分布
iOS操作系统分布

UI兼容适配

不同屏幕分辨率参考如下,除常规分辨率外,还应关注刘海屏:


Android设备分辨率分布
iOS设备分辨率分布

小程序版本&微信版本兼容

小程序的功能实现依赖小程序基础库,而小程序基础库需要依赖微信客户端本身,因此当我们的小程序使用了某些相对于微信客户端自带的基础库版本较新的API时,就会出现兼容问题。我们在测试时应确保测试覆盖到市场占有率较高的微信版本。
为了避免新版本的基础库给线上小程序带来未知的影响,微信客户端都是携带上一个稳定版的基础库发布的。
在新版本客户端发布后,再通过后台灰度新版本基础库,灰度时长一般为 12 ~ 24 小时,在灰度结束后,用户设备上才会有新版本的基础库。
以微信 6.5.8 为例,客户端在发布时携带的是 1.1.1 基础库(6.5.7 上已全量的稳定版)发布,在 6.5.8 发布后,我们再通过后台灰度 1.2.0 基础库。

基础库版本分布

更新时间:2020 年 6 月 17 日

占比低于 0.01% 的版本已隐藏,灰度发布中的版本也会显示。

基础库版本 安卓版本 安卓用户占比 iOS版本 iOS用户占比 总体占比
2.11.2 7.0.13 3.08% 7.0.12 4.17% 3.34%
2.11.1 - 84.69% - 80.87% 83.77%
2.11.0 - 0.08% - 0.01% 0.06%
2.10.4 7.0.9 8.49% 7.0.9 8.20% 8.42%
2.10.3 - 0.09% - - 0.07%
2.10.1 - 0.01% - - 0.01%
2.9.5 7.0.7 0.85% 7.0.7 2.60% 1.27%
2.9.3 - 0.02% - - 0.02%
2.8.3 7.0.5 1.09% 7.0.5 1.09% 1.09%
2.7.7 7.0.4 0.54% 7.0.4 0.83% 0.61%
2.7.1 - 0.01% - - 0.01%
2.6.6 7.0.3 0.55% 7.0.3 0.92% 0.64%
2.5.2 7.0.0 0.17% 7.0.0 0.34% 0.21%
2.4.4 6.7.3 0.15% 6.7.3 0.52% 0.24%
2.3.2 6.7.2 0.02% 6.7.2 0.12% 0.05%
2.2.5 6.6.7 0.06% 6.7.0 0.11% 0.08%
2.1.3 - - 6.6.7 0.04% 0.01%
2.0.9 6.6.6 0.03% 6.6.6 0.07% 0.04%
1.9.97 6.6.2 0.03% 6.6.2 0.05% 0.03%
1.9.9 6.6.1 0.01% 6.6.1 0.03% 0.01%

性能

小程序前端性能分为启动性能和运行时性能,启动性能关注启动总耗时、首屏时间,运行时性能主要关注页面切换耗时和内存消耗、内存异常。

测试方法

微信小程序官方提供了两种性能分析工具,一个体验评分插件。两个工具分别是性能面板和性能Trace工具,而体验评分插件是微信开发者工具中使用,性能Trace工具只支持Android设备,这里不做介绍。

体验评分工具

使用流程

???? 1.打开开发者工具,在详情里切换基础库到 2.2.0 或以上版本。
???? 2.在调试器区域切换到 Audits 面板。
???? 3.点击”开始“按钮,然后自行操作小程序界面,运行过的页面就会被“体验评分”检测到。

????4.点击 “停止" 则结束检测,在当前面板显示相应的检测报告,开发者可根据报告中的建议对相应功能进行优化。
????5.如需再次运行体验评分,可点击报告上方的“清空体验评分”恢复初始状态。请注意,目前系统不提供报告存储服务,一旦清空体验评分,将无法再查看本次评分结果。

自动运行

为了方便开发者能够及时发现小程序的体验问题,从开发者工具 1.02.1811150 版本起支持体验评分的 “自动运行” 功能。

该功能会在开发调试小程序时,实时检查,一旦发现体验分数低于 70 分时,系统会在 console 面板打印一个 warning 信息提示开发者,此时开发者可以切到 Audits 面板查看详情。

开发者在工具的右上角 “详情” 面板的 本地设置 中勾选 “自动运行体验评分” 选项即可开启。

体验评分关注性能板块给出的问题列表即可:

体验评分性能指标
1. 首屏时间

首屏时间是指用户从打开小程序看到第一屏主要内容的时间,首屏时间太长会导致用户长时间看到的都是白屏,影响使用体验。

优化首屏时间,可以分为以下几种情况:

???? 1. 首屏渲染的内容较多,需要集合多份数据进行渲染。这种情况需要开发者把内容分优先级,把优先级高的内容做优先展示,缩短白屏时间;
???? 2. 首屏内容依赖的数据从服务端请求的时间太长。开发者需要从服务端侧具体分析服务端数据返回的时间长的原因;
???? 3. 一次性渲染数据太大或依赖的计算过于复杂。减少渲染的数据量、优化渲染相关数据的算法可以解决这类问题。

得分条件:首屏时间不超过 5 秒

2. 渲染时间

渲染时间指的是首次渲染或因数据变化带来的页面结构变化的渲染花费的时间。

渲染界面的耗时过长会让用户觉得卡顿,体验较差,出现这一情况时,需要校验下是否同时渲染的区域太大(例如列表过长),或渲染依赖的计算是否过于复杂。

得分条件:渲染时间不超过 500ms

3. 脚本执行时间

脚本执行时间是指JS脚本在一次同步执行中消耗的时间,比如生命周期回调、事件处理函数的同步执行时间。

执行脚本的耗时过长会让用户觉得卡顿,体验较差,出现这一情况时,需要确认并优化脚本的逻辑

得分条件:一个执行周期内脚本运行时间不超过 1 秒

4. setData调用频率

setData接口的调用涉及逻辑层与渲染层间的线程通信,通信过于频繁可能导致处理队列阻塞,界面渲染不及时而导致卡顿,应避免无用的频繁调用。

得分条件:每秒调用setData的次数不超过 20 次

5. setData数据大小

由于小程序运行逻辑线程与渲染线程之上,setData的调用会把数据从逻辑层传到渲染层,数据太大会增加通信时间。

得分条件:setData的数据在JSON.stringify后不超过 256KB

6. 避免setData数据冗余

setData操作会引起框架处理一些渲染界面相关的工作,一个未绑定的变量意味着与界面渲染无关,传入setData会造成不必要的性能消耗。

得分条件:setData传入的所有数据都在模板渲染中有相关依赖

7. WXML节点数

建议一个页面使用少于 1000 个 WXML 节点,节点树深度少于 30 层,子节点数不大于 60 个。一个太大的 WXML 节点树会增加内存的使用,样式重排时间也会更长,影响体验。

得分条件:页面WXML节点少于 1000 个,节点树深度少于 30 层,子节点数不大于 60 个

8. 图片缓存

开启 HTTP 缓存控制后,下一次加载同样的图片,会直接从缓存读取,大大提升加载速度。

得分条件:所有图片均开启 HTTP 缓存

9. 图片大小

图片太大会增加下载时间和内存的消耗,应根据显示区域大小合理控制图片大小。

得分条件:图片宽高都不超过实际显示宽高的3倍

10. 请求耗时

请求的耗时太长会让用户一直等待甚至离开,应当优化好服务器处理时间、减小回包大小,让请求快速响应。

得分条件:所有网络请求都在 1 秒内返回结果

11. 网络请求数

短时间内发起太多请求会触发小程序并行请求数量的限制,同时太多请求也可能导致加载慢等问题,应合理控制请求数量,甚至做请求的合并等。

得分条件:每秒通过wx.request发起的请求数不超过 10 个

12. 图片请求数

短时间内发起太多图片请求会触发浏览器并行加载的限制,可能导致图片加载慢,用户一直处理等待。应该合理控制数量,可考虑使用雪碧图技术或在屏幕外的图片使用懒加载。

得分条件:每秒发起的图片请求数不超过 20 个

13. 网络请求缓存

发起网络请求总会让用户等待,可能造成不好的体验,应尽量避免多余的请求,比如对同样的请求进行缓存

得分条件:3 分钟以内同一个url请求不出现两次回包大于 128KB 且一模一样的内容

性能面板

打开方法:进入开发版小程序,进入右上角更多按钮,点击「显示性能窗口」


性能面板指标说明:

指标 说明
CPU 小程序进程的 CPU 占用率,仅 Android 下提供
内存 小程序进程的内存占用(Total Pss),仅 Android 下提供
启动耗时 小程序启动总耗时
下载耗时 小程序包下载耗时,首次打开或资源包需更新时会进行下载
页面切换耗时 小程序页面切换的耗时
帧率/FPS
首次渲染耗时 页面首次渲染的耗时
再次渲染耗时 页面再次渲染的耗时(通常由开发者的 setData 操作触发)
数据缓存 小程序通过 Storage 接口储存的缓存大小

细心的你可能已经发现,CPU和内存指标在性能面板上只支持Android客户端,另外你可能也发现了,性能面板只有实时数据,有没有一个统一的汇总数据?看下边

小程序助手

使用[小程序助手]中「性能分析」板块,来持续关注小程序性能。性能分析从 启动性能、运行性能和网络性能三个维度提供性能数据,可根据平台、机型、网络环境和访问来源等条件做精细化分析。扫描下方小程序码即可立即体验。

?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351