2017.01.09 小程序上线时,微信限制了代码包不能超过1MB 大小,(现在是2M了)限制大小是出于对小程序启动速度的考虑,希望用户在使用任何一款小程序时,都能获得一种“秒开”体验。然而,2MB 的大小也限制了小程序功能的扩展,小程序业务的发展可能需要更大的体积。
那么,能否有一种方案,在增加小程序包大小的同时,也能保持不错的启动速度呢?
为了解决这个矛盾点,微信推出了「分包加载」这个技术方案。

分包加载的介绍
大部分小程序都会由某几个功能组成,通常这几个功能之间是独立的,但会依赖一些公共的逻辑,并且这些功能通常会对应某几个独立的页面。那么小程序代码的打包,大可不必一定要打成一个,可以按照功能的划分,拆分成几个分包,当需要用到某个功能时,才加载这个功能对应的分包。
对于用户来说,小程序加载流程变成了:

1.首次启动时,先下载小程序主包,显示主包内的页面;

2.如果用户进入了某个分包的页面,再下载这个对应分包,下载完毕后,显示分包的页面。

采用分包加载,对开发者而言,能使小程序有更大的代码体积,承载更多的功能与服务;而对用户而言,可以更快地打开小程序,同时在不影响启动速度前提下使用更多功能

分包的划分

在配置前首先需要开发者规划下各个分包需要容纳的内容,我们建议开发者按照功能划分的的原则,将同一个功能下的页面和逻辑放置于同一个目录下,对于一些跨功能之间公共逻辑,将其放置于主包下,这样可以确保在分包引用这部分功能时,这部分的逻辑一定存在。

在分包划分时,应该注意以下事项:

1.避免分包与分包之间引用上的耦合。因为分包的加载是由用户操作触发的,并不能确保某分包加载时,另外一个分包就一定存在,这个时候可能会导致 JS 逻辑异常的情况,例如报「“xxx.js” is not defined」这样的错误;

2.一些公共用到的自定义组件,需要放在主包内。

分包的配置

当理清了分包的划分后,就可以进行分包的配置了,这一步并不复杂。

假设支持分包的小程序目录结构如下:

开发者通过在 app.jsonsubPackages字段声明项目分包结构:

代码:

{"pages": ["pages/home/home","pages/index/index",],"subPackages": [{"root": "packageA","pages": ["pages/blog/blog"]},{"root": "packageB","pages": ["pages/catalog/catalog"]},{"root": "packageC","pages": ["pages/kongtiao/kongtiao"]}],
}

分包加载的低版本兼容问题

微信 6.6.0 版本开始支持分包加载,而对于低于这个版本的客户端,我们做了兼容处理,开发者不需要对老版本微信客户端做兼容。

对于老版本的客户端,编译后台会将所有的分包打包成一个整包,老版本的客户端依然按照整包的方式进行加载。
所以在老版本的微信客户端下,是依然采取整包加载的方式加载的,建议开发者尽量控制代码包的大小。
目前小程序分包大小的限制:

  • 整个小程序所有分包大小不超过 4M
  • 单个分包/主包大小不能超过 2M

随着时间推移,老版本覆盖率降低,我们会考虑进一步扩大代码包的大小。

分包加载的详细使用方法、示例项目文档上已有介绍,可查看接口文档:分包加载

如果其他问题,欢迎在评论区留言。

  • END -

如果大家有想了解的小程序相关能力的故事,欢迎在评论区留言,我们后续会考虑将这些能力背后的故事分期分享给大家。


码字不易,在线求个三连支持。

大家记得收藏前,先点个赞哦!好的文章值得被更多人看到。

关注江哥不迷路,带你编程上高速。

微信公众号关注:江小鱼吧 免费领取高级前端学习资料,转身涨薪20K

支付宝生态技术学习交流群:
加入Q群与更多BAT一线大佬深度交流:1136157571 (点我入群)


微信小程序之分包加载,解决代码超过2M的方法相关推荐

  1. 微信小程序的分包加载

    文章目录 前情提要 小程序的包结构 app.json声明包结构 独立分包 声明独立分包 分包预下载 声明分包预下载 搭建静态资源服务器 小程序项目 app.json 主包 app.wxss app.j ...

  2. 微信小程序上拉加载更多

    微信小程序上拉加载更多 无论是微信小程序还是其他前端框架,都会遇到上拉加载(懒加载)和下拉刷新这种问题.其实理清楚什么时候请求数据.请求返回的几种情况,那么做这个懒加载就很简单了. 一.首先,固定一个 ...

  3. 微信小程序图标不支持html,微信小程序实现自定义加载图标功能

    效果图 实现思路 1.首先通过HTML+CSS实现加载动画的静态效果: 2.根据需求给每个动画设计不同的动画效果. 例如第一个加载图标的静态绘制 1.首先确定动画的盒子宽高: 2.设置盒子中每一个长方 ...

  4. 微信小程序之下拉加载和上拉刷新

    微信小程序之下拉加载和上拉刷新 微信小程序下拉加载和上拉刷新两种实现方法 方法一:onPullDownRefresh和onReachBottom方法实现小程序下拉加载和上拉刷新 首先要在json文件里 ...

  5. Android 仿微信小程序开屏页加载loading

    Android 仿微信小程序开屏页加载loading 废话不多说,先上效果图~ 首先就是底层有一个灰色的圆,然后按照圆形的轨迹进行绘制. 啊~说那么多也没用,还是直接上代码吧,哈哈哈哈 绘制底部圆形及 ...

  6. 【微信小程序】自定义加载动画3

    目录 效果图 配置 版本1 版本2 结语 效果图 配置 配置方法参考上一篇文章:[微信小程序]自定义加载动画 版本1 Component({behaviors

  7. 【微信小程序】自定义加载动画4

    目录 效果图 配置文件 结语 效果图 配置文件 配置方法参考上一篇文章:[微信小程序]自定义加载动画 组件源代码: Component({behaviors: [],properties: {

  8. 微信小程序封装懒加载图片

    微信小程序封装懒加载图片 js /components/LazyImage/index.js // components/LazyImage/index.js Component({/*** 组件的属 ...

  9. 微信小程序上拉加载流程

    微信小程序上拉加载流程 1.首先需要在微信官方文档把scroll-view这个方法引入进来,然后使用这个方法,在样式里面写scroll-y,代表的是上下滑动,然后给滑动的盒子一个高度,100vh,然后 ...

最新文章

  1. 计算机应用基础考试试题及答案 在word中,用户建立的文件默认,天津大学《计算机应用基础》2016年12月考试期末大作业考核试题...
  2. Java中的occur_time,PLSQL报错: ORA-12170:TNS connect timeout occurred
  3. 使用 Android 实现联网
  4. 光纤通道速率查看_基于OM3/OM4的光纤通道连接方案
  5. session图片验证码,页面和请求是两个地址。android手机好用,iphone 失效。
  6. Java Code之多态
  7. Apache日志切割shell脚本
  8. 商业认知,新的一年开始了
  9. 使用Material Design的Flutter应用
  10. PC/UVA 110405/10026 Shoemaker's problem
  11. python类的多态_8.python之面相对象part.6(python类中的多态与多态性)
  12. 需求分析报告和需求规格说明书有什么区别
  13. Spring AOP高级——源码实现(2)Spring AOP中通知器(Advisor)与切面(Aspect)
  14. linux查看trunk信息,linux网卡启用trunk模式操作标准.docx
  15. bert之我见-attention
  16. 如何用仅用C语言判断编译器的大小端
  17. 【IPD流程学习 一】背景和目标
  18. 迅雷快车旋风链接转换成普通链接工具
  19. 工业设计公司如何进行家电设计创新?
  20. 【区块链】Web3.0黑话合集:区块链/Token等专业术语

热门文章

  1. 最新iscsi服务器,适用于Windows的一款先进,强大,多功能的iscsi 服务器软件。
  2. UI设计师如何自学?
  3. 角蜂鸟AI视觉套件1:开箱和开发环境搭建
  4. 相对数时间序列--平均发展水平
  5. 【C语言练习】7-4 关于奇数的等式
  6. 在高铁上写代码,还被抖音网红跟拍
  7. 那些年 WooYun 的漏洞
  8. 今天给大家分享使用Scratch做一个单机版足球赛的游戏!
  9. android vlc 中文字幕,解决Android版vlc中文乱码问题
  10. 爬虫自定义创建Opener