微信小程序-分包加载

server/2024/10/19 3:32:59/

文章目录

  • 小程序>微信小程序-分包加载
    • 概述
    • 基本使用
    • 打包和引用原则
    • 独立分包
    • 分包预下载

小程序>微信小程序-分包加载

概述

小程序的代码通常是由许多页面、组件以及资源等组成,随着小程序功能的增加,代码量也会逐渐增加,体积过大就会导致用户打开速度变慢,影响用户的使用体验。

开发者需要将小程序划分成不同的子包,在构建时打包成不同的分包,用户在使用时按需进行加载。在小程序启动时,默认会下载主包并启动主包内页面,当用户进入分包内某个页面时,客户端会把对应分包下载下来,下载完成后再进行展示。

主包: 放置默认启动页面/TabBar 页面,以及一些所有分包都需用到公共资源/JS 脚本。

分包: 是根据开发者的配置进行划分。

小程序分包大小限制:

  • 整个小程序所有分包大小不超过 30M(服务商代开发的小程序不超过 20M)
  • 单个分包/主包大小不能超过 2M

在这里插入图片描述

基本使用

配置:

  • 在 app.json 文件中配置 subPackages 声明分包。
  • 每个分包必须指定 root 字段、name 字段、pages 字段:
    • root:指定分包的根目录。
    • name:指定分包的别名。
    • pages:指定分包中包含的页面。

具体代码:

"subPackages": [{"root": "modules/goodModule","name": "goodModule","pages": ["pages/list/list","pages/detail/detail"]},{"root": "modules/markModule","name": "markModule","pages": ["pages/market/market"]}
],

查看:

点击右边的“详情” -> “本地代码” -> “代码依赖分析”,可以看到如下,由此可知目前有一个主包和两个分包。

在这里插入图片描述

点击主包可查看有3个页面,如下:

在这里插入图片描述

跳转分包页面:

主包 -> 分包:

<navigator url="/modules/goodModule/pages/list/list">跳转list页面</navigator>

分包 -> 分包:

<navigator url="../detail/detail">跳转detail页面</navigator>

打包和引用原则

打包原则:

  • 声明 subPackages 后,将按 subPackages 配置路径进行打包,subPackages 配置路径外的目录将被打包到主包中
  • 主包也可以有自己的 pages,即最外层的 pages 字段。
  • subPackages 的根目录不能是另外一个 subPackages 内的子目录
  • tabBar 页面必须在主包内

引用原则:

  • 主包不可以引用分包的资源,但分包可以使用主包的公共资源
  • 分包与分包之间资源无法相互引用, 分包异步化时不受此条限制

独立分包

独立分包是小程序中一种特殊类型的分包,可以独立于主包和其他分包运行

  • 如果是独立分包,不需要下载主包,直接就能够访问,独立分包是自己独立运行的。

  • 而如果是其他分包,需要先下载主包,通过路径访问,才能加载对应路径的分包。

注意:

  1. 独立分包中不能依赖主包和其他分包中的资源。

  2. 主包中的 app.wxss 对独立分包无效。

  3. App 只能在主包内定义,独立分包中不能定义 App,会造成无法预期的行为。

配置:

在 app.json 文件中找到 subPackages 字段,在指定分包中配置 independent 字段。

"subPackages": [{"root": "modules/goodModule","name": "goodModule","pages": ["pages/list/list","pages/detail/detail"]},{"root": "modules/markModule","name": "markModule","pages": ["pages/market/market"],"independent": true}
]

分包预下载

分包预下载是指访问小程序某个页面时,预先下载分包中的代码和资源,以提高用户的使用体验。当用户需要访问分包中的页面时,已经预先下载的代码和资源可以直接使用,通过分包预下载加快了页面的加载速度和显示速度。

配置:

在 app.json 文件中配置 preloadRule。

preloadRule 是一个对象,key 表示进入的页面,value 表示预下载的配置。

字段类型必填默认值说明
packagesStringArray进入页面后预下载分包的 rootname__APP__ 表示主包。
networkStringwifi在指定网络下预下载,可选值为: all: 不限网络 wifi: 仅wifi下预下载
"preloadRule": {// 进入index页面,预下载goodModule分包"pages/index/index": {"network": "all","packages": ["modules/goodModule"]},// 进入market页面,预下载主包"modules/markModule/pages/market/market": {"network": "all","packages": ["__APP__"]}
},

http://www.ppmy.cn/server/124429.html

相关文章

基于Python的人工智能应用案例系列(14):Fashion MNIST图像分类CNN

在这一篇文章中&#xff0c;我们将使用PyTorch来实现卷积神经网络&#xff08;CNN&#xff09;&#xff0c;对Fashion MNIST数据集进行图像分类任务。Fashion MNIST数据集是MNIST的升级版&#xff0c;包含各种服装、鞋类和配饰的灰度图像&#xff0c;非常适合作为深度学习的入门…

Java项目实战II基于Java+Spring Boot+MySQL的新闻稿件管理系统(源码+数据库+文档)

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末 一、前言 前在信息爆…

mysql数据库设置主从同步

mysql数据库设置主从同步 环境 mysql主库版本MySQL-5.6.40-2.sles12.x86_64 mysql从库版本mysql-5.7.21-linux-glibc2.12-x86_64 一、主库配置 修改主库my.cnf配置 [mysqld] #server_id 1 #唯一标识&#xff0c;主库从库不能重复 #log_bin mysql-bin …

jdk1.6版本发送HTTPS请求,报错Could not generate DH keypair问题解决

Could not generate DH keypair问题 这个问题一般出现在因为jdk版本过低&#xff0c;而接收请求的服务器设置接收的加密算法不持支这个从而导致的,解决方式有多个&#xff1a; 直接了当更新jdk版本&#xff0c;更新到服务器所支持的jdk版本很多时候&#xff0c;更新jdk版本会…

COSCon'24 第九届中国开源年会议题征集正式启动

一年一度的开源盛会&#xff0c;COSCon24 第九届中国开源年会暨开源社十周年嘉年华将于2024年11月2-3日在中关村国家自主创新示范区会议中心举办。在为期2天的大会中&#xff0c;我们将为大家带来精彩纷呈的 Keynote 主题演讲&#xff08;上午&#xff09;&#xff0c;和百花齐…

Java项目实战II基于Java+Spring Boot+MySQL的植物健康系统(开发文档+源码+数据库)

目录 目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末 一、前言 随着…

MacOS上安装MiniConda的详细步骤

前言 MiniConda是一种环境配置工具。在不同的开发项目中&#xff0c;我们会使用到不同版本的Python和第三方库&#xff08;例如Numpy、Pandas)。如果不使用环境配置工具&#xff0c;每次开发都需要清除电脑里上一次开发的环境和配置文件。为了在同一台机器上同时开发多个项目&…

【C语言从不挂科到高绩点】23-指针05-结构体指针【重点知识】

Hello!彦祖们,俺又回来了!!!,继续给大家分享 《C语言从不挂科到高绩点》课程!! 本节将为大家讲解C语言中非常重要的知识点-指针: 本套课程将会从0基础讲解C语言核心技术,适合人群: 大学中开设了C语言课程的同学想要专升本或者考研的同学想要考计算机等级证书的同学想…