微信小程序性能优化方案

微信小程序性能优化方案

微信小程序如果想要优化性能,有关键性的两点:

  1. 提高加载性能
  2. 提高渲染性能

提高加载性能

首先,我们需要了解,当用户点击小程序后小程序启动的流程,具体详细的流程在微信官方文档 启动性能 中有描述,以下的篇章我们主要着重于我们能够改变优化的环节。

小程序代码包准备(下载代码包) => 开发者代码注入(逻辑和渲染) => 首页(初次)渲染

小程序代码包准备(下载代码包)

下载代码包提升性能的最关键性一点就是,控制代码包的大小。

至于如何控制包的大小?

  1. 分包加载
    我在另一篇博客中具体讲解了分包加载,大家可以移步去学习
    小程序分包加载实践
  2. 代码重构和优化
    通过代码重构,降低代码冗余。在使用如 Webpack 等打包工具时,要尽量利用 tree-shaking 等特性去除冗余代码,也要注意防止打包时引入不需要的库和依赖。
  3. 控制代码包内图片等资源
    避免在代码包中包含过多、过大的图片,应尽量采用网络图片。
  4. 及时清理没有使用到的代码和资源
    目前小程序打包是会将工程下所有文件都打入代码包内,因此需要及时清理已经没有被实际使用到的库文件和资源也。

开发者代码注入

  1. 减少启动过程的同步调用
    在小程序启动流程中,会注入开发者代码并顺序同步执行 App.onLaunch, App.onShow, Page.onLoad, Page.onShow。
    在小程序初始化代码(Page,App 定义之外的内容)和启动相关的几个生命周期中,应避免执行复杂的计算逻辑或过度使用Sync结尾的同步API,如 wx.getStorageSync,wx.getSystemInfoSync 等。
    对于 getSystemInfo, getSystemInfoSync 的结果应进行缓存,避免重复调用。

  2. 使用懒注入
    通常情况下,在小程序启动时,启动页面所在分包和主包(独立分包除外)的所有JS代码会全部合并注入,包括其他未访问的页面以及未用到自定义组件,造成很多没有使用的代码注入到小程序运行环境中,影响注入耗时和内存占用。

自基础库版本 2.11.1 起,小程序支持仅注入当前页面需要的自定义组件和当前页面代码,以降低小程序的启动时间和运行时内存。开发者可以在 app.json 中配置:

{
   
  "lazyCodeLoading": 
  • 7
    点赞
  • 58
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值