小程序分包以及分包页面的分享

本文介绍了小程序分包的原因、步骤及预下载机制。分包允许整个小程序不超过8M,单个分包不超过2M。启动时默认下载主包,进入分包页面时客户端会下载对应分包。分包支持的基础库版本为2.3.0以上,预下载配置在app.json的preloadRule字段。独立分包在6.7.2及以上版本支持,可提升分包页面启动速度,无需下载主包。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.分包

为什么使用分包
小程序第一版 推出 小程序代码包不能超过1MB 大小,所以,小程序可以秒开,但是随着业务的发展,又推出整个小程序所有分包大小不超过 8M,而8M不能秒开,于是就推出分包加载。

对于小程序而言

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

在小程序启动时,默认会下载主包并启动主包内页面
当用户用户进入分包内某个页面时,客户端会把对应分包下载下来,下载完成后再进行展示。

分包支持的版本
微信客户端6.6.0,基础库 1.7.3 及以上版本开始支持。开发者工具请使用 1.01.1712150 及以上版本
转载:https://www.jianshu.com/p/e51316e15a6a

2.小程序的分包步骤

step1:
添加项目目录

├── app.js
├── app.json
├── app.wxss
├── packageA
│ └── pages
│ ├── cat
│ └── dog
├── packageB
│ └── pages
│ ├── apple
│ └── banana
├──pages
│ ├── index
│ └── logs
└── utils

step2:
在app.json中的目录结构中添加分包目录(subpackagessubPackages都可以)

{
  "pages":[
    "pages/index",
    "pages/logs"
  ],
  "subpackages": [
    {
      "root": "packageA",
      "pages": [
        "pages/cat",
        "pages/dog"
      ]
    }, {
      "root": "packageB",
      "name": "pack2",
      "pages": [
        "pages/apple",
        "pages/banana"
      ]
    }
  ]
}

}
step3:
分包配置
subpackages里面的配置项包括

root String 分包根目录
name String 分包别名,分包预下载时可以使用
pages StringArray分包页面路径,相对与分包根目录
independent Boolean 分包是否是独立分包

打包规则

1.声明 subpackages 后,将按 subpackages 配置路径进行打包,2.subpackages 配置路径将作为分包打包,其他都被打包到 app(主包) 中
3.app(主包)也可以有自己的 pages(即最外层的 pages 字段)
4.subpackage 的根目录不能是另外一个 subpackage 内的子目录
5.tabBar 页面必须在 app(主包)内
6.每个分包都可以使用自己分包内的资源以及引用require app里面的资源,但是分包与分包之间 ,都是不可通信的,分包与主包下的pages里面的内容也是不可通信的(这一点有待考证)

分包预下载

基础库 2.3.0 开始支持,低版本需做兼容处理。 开发者工具请使用 1.02.1808300 及以上版本,可点此下载
目前只支持通过配置方式使用,暂不支持通过调用API完成

通过配置,在进入小程序某个页面时,由框架自动预下载可能需要的分包,提升进入后续分包页面时的启动速度。

配置方法
在app.json中增加 preloadRule 配置来控制。

{
  "pages": ["pages/index"],
  "subpackages": [
    {
      "root": "important",
      "pages": ["index"],
    },
    {
      "root": "sub1",
      "pages": ["index"],
    },
    {
      "name": "hello",
      "root": "path/to",
      "pages": ["index"]
    },
    {
      "root": "sub3",
      "pages": ["index"]
    },
    {
      "root": "indep",
      "pages": ["index"],
      "independent": true
    }
  ],
  "preloadRule": {
    "pages/index": {
      "network": "all",
      "packages": ["important"]
    },
    "sub1/index": {
      "packages": ["hello", "sub3"]
    },
    "sub3/index": {
      "packages": ["path/to"]
    },
    "indep/index": {
      "packages": ["__APP__"]
    }
  }
}

以上配置

key 是页面路径,value 是进入此页面的预下载配置

packages的 value是StringArray 类型,表示进入页面后预下载分包的 root 或 name。APP 表示主包

network 是string类型 默认 为 ‘wifi’ ,标识在指定网络下预下载,
可选值为
all: 不限网络
wifi: 仅wifi下预下载

同一个分包中的页面享有共同的预下载大小限额 2M(一个分包内的所有页面加总只有2M预下载),限额会在工具中打包时校验。

独立分包

小程序游戏不支持独立分包。

微信客户端 6.7.2,基础库 2.3.0 及以上版本开始支持。开发者工具请使用 1.02.1808300 及以上版本,可点此下载

1.从独立分包中页面进入小程序时,不需要下载主包。
2.从普通的分包页面进入小程序时,首先下载主包;

优势:提升分包页面的启动速度。

配置方法
app.json的subpackages字段中对应的分包配置项中定义independent字段声明对应分包为独立分包。

{
  "pages": [
    "pages/index",
    "pages/logs"
  ],
  "subpackages": [
    {
      "root": "moduleA",
      "pages": [
        "pages/rabbit",
        "pages/squirrel"
      ]
    }, {
      "root": "moduleA",
      "pages": [
        "pages/pear",
        "pages/pineapple"
      ],
      "independent": true
    }
  ]
}
### 微信小程序分包加载与页面跳转实现 微信小程序支持通过分包的方式优化应用性能,减少主包体积并提高加载速度。以下是关于分包页面跳转的具体实现方法及相关常见问题的解决方案。 #### 一、分包页面跳转的基本实现 在微信小程序中,无论是主包还是分包页面之间的跳转均遵循统一的路由规则。可以通过 `wx.navigateTo` 或 `wx.redirectTo` 方法完成页面跳转操作[^4]: ```javascript // 跳转至分包内的某个页面 wx.navigateTo({ url: '/packageA/pages/detail/detail?id=1', }); ``` 需要注意的是,如果目标页面位于独立分包中,则需要确保该分包已正确配置为独立运行状态。否则可能会因资源未加载而导致错误。 --- #### 二、分包加载失败的原因分析及解决办法 根据实际开发经验,分包加载失败可能由以下原因引起,并提供相应解决方案[^2]: 1. **网络条件不足** - 如果用户的设备处于较差的网络环境中(如信号弱或无网络连接),可能导致分包无法成功下载。 - 解决方案:建议设置合理的预加载策略,优先在网络状况良好时加载必要的分包资源。 2. **缓存冲突** - 当用户本地存在旧版本的小程序文件时,可能出现新旧版本间的兼容性问题,从而引发分包加载异常。 - 解决方案:定期清理测试环境中的历史数据;正式上线前务必进行全面灰度测试以验证稳定性。 3. **路径配置错误** - 若项目结构发生变化但未同步更新 app.json 中的相关定义项,则会造成找不到对应的目标文件。 - 解决方案:仔细核对所有涉及分包的部分是否按照最新标准进行了调整。 4. **超限尺寸限制** - 单个分包大小不得超过 2MB (压缩后),超出此范围会被拒绝上传至云端服务器。 - 解决方案:合理规划各部分功能划分,避免单一分包承载过多内容。 --- #### 三、利用预加载提升效率 为了进一步改善用户体验,可借助 `preloadRule` 字段预先获取即将使用的子模块资料[^3]。例如: ```json { "pages": [ "pages/index/index" ], "subpackages": [ { "root": "subpackage", "pages": ["pages/about/about"] } ], "preloadRule": { "pages/index/index": { "network": "all", "packages": ["subpackage"] } } } ``` 上述代码片段表明,在初次进入首页的同时也会默默准备好 “about” 页面所属的数据集以便随时调用。 --- #### 四、注意事项 - 对于 tabbar 类型的应用界面设计而言,由于其特殊性质,默认情况下不允许直接指向外部链接地址作为菜单入口之一。因此若希望某一项标签关联到特定位置的话,就需要额外处理逻辑来满足这一需求[^3]。 - 开发者工具模拟器虽然方便快捷,但在排查真实环境下发生的故障现象时常显得力不从心。所以必要时候还需配合抓包软件 Charles 来深入观察整个交互过程是否存在潜在隐患。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值