【微信小程序之分包】

微信小程序之分包

什么是分包

分包指的是把一个完整小程序项目,按照需求划分为不同的子包,在构建时打包成不同的分包,用户在使用时按需进行加载。

分包的好处

  1. 可以优化小程序首次启动的时间
  2. 在多团队共同开发时可以更好的解耦合作

分包前的结构图

分包前,小程序项目中的所有页面和资源都被打包在一起,导致整个项目体积过大,影响小程序首次启动的下载时间

分包后的结构图

分包hou,小程序由主包和多个分包组成:

------主包:一般只包含项目的启动页面或TabBar页面,以及所有分包都需要用到的一些公共资源

------分包:只包含当前分包有关的页面和资源

分包的加载规则

(1)在小程序启动时,默认会下载主包并启动主包内页面,TabBar页面需要放到主包中

(2)当用户进入分包内的某个页面时,客户端会把对应的分包下载下来,进行按需下载

分包的体积限制

小程序所有包的体积不能超过16M

单个包(主/分包)大小不能超过2M

使用分包

javascript 复制代码
{
 "subPackages": [
       {
          "root" :"pkgA" ,
          "pages" : [
              "pages/cat/cat",
              "pages/dog/dog"
          ]
          
      },
      {
        "root" :"pkgB" ,
        "pages" : [
            "pages/apple/apple",
            "pages/banana/banana"
        ]


      }



  ],
  }

打包原则

(1)小程序会按照subPackages的配置进行分包,subPackages之外的目录将被打包到主包中

(2)tabBar页面必须在主包里面

(3)分包之间不能相互嵌套

引用原则

(1)主包无法引用分包内的私有资源

(2)分包之间不能相互引用私有公告资源

(3)分包可以引用主包内的公告资源

独立分包

独立分包本质上也是分包,不过他可以独立于主包和其他分包单独运行,也就是说没有什么依赖,而普通分包不能,单独运行。

独立分包的配置方法

独立分包的引用原则

(1)独立分包不能引用主包中的公共资源

(2)主包无法引用独立包内的私有资源

(3)独立分包之间也不允许相互引用私有资源

(4)独立分包和普通分包之间,不能引用私有资源

分包预下载

在小程序进入页面时,由框架自动预下载可能需要的分包,从而提升进入后续分包页面时的启动速度

配置分包的预下载

分包预下载限制

------------一个分包的的预下载总大小不能超过2M

相关推荐
2501_916007472 小时前
TCP 抓包分析实战,从三次握手到自定义协议解析的完整方法
网络协议·tcp/ip·ios·小程序·uni-app·php·iphone
前端开发呀6 小时前
成为开源项目的Contributor:从给uView-pro 贡献一次PR开始
前端·微信小程序
Dark_programmer8 小时前
钉钉小程序 - - - - - 小程序内跳转其他小程序
小程序·apache·钉钉
kyh100338112010 小时前
可商用去水印微信小程序源码(免费获取全部源码)
微信小程序·小程序·微信小游戏·去水印·去水印工具·微信去水印小程序
2501_9151063211 小时前
H5 混合应用加密实践,从明文资源到安全 IPA 的多层防护体系
android·安全·ios·小程序·uni-app·iphone·webview
我命由我1234512 小时前
微信小程序 - 页面返回并传递数据(使用事件通道、操作页面栈)
开发语言·前端·javascript·微信小程序·小程序·前端框架·js
半开半落12 小时前
uniapp微信小程序端接收ai模型返回的SSE流式数据
微信小程序·小程序·uni-app·ai模型
2501_9160074712 小时前
在 CICD 中实践 Fastlane + Appuploader 命令行,构建可复制的 iOS 自动化发布流程
android·运维·ios·小程序·uni-app·自动化·iphone
一匹电信狗12 小时前
【Linux我做主】进程实践:手动实现Shell
linux·运维·服务器·c++·ubuntu·小程序·开源
奺儿13 小时前
uniapp 小程序 报错 TypeError: Cannot convert undefined or null to object
小程序·uni-app