免费试用

跨平台小程序在线开发工具,用做网页的技术做小程序,兼容微信、支付宝、抖音、快手、百度等主流小程序平台!

uniapp开发的微信小程序分包

Uniapp是一款多端开发框架,支持开发微信小程序、H5、APP等多端应用。在开发微信小程序时,由于小程序限制单包大小必须不超过2MB,而一些项目需要引入大量的第三方库和图片资源,因此需要采用分包的方式来解决单包大小限制的问题。

一、分包原理

Uniapp中的分包原理是将项目中的文件按照指定的规则拆分成多个包,这些包在小程序启动后会异步加载并进行合并。当需要使用分包中的某个组件或页面时,Uniapp会自动加载该分包,并且只有在需要的时候才会加载分包中的其他组件和页面,以此来减小小程序的启动时间和提高用户体验。

分包的实现原理是在app.json文件中指定subpackages字段,该字段是一个数组类型,里面每一个对象都代表一个分包,并包含以下字段:

1. name:分包名称,必填项。

2. root:分包文件路径,相对于根目录,必填项。

3. pages:分包中的所有页面路径,可选项。

其中,name字段表示分包名称,将多个页面放在同一个分包中,可以方便的根据业务划分分包;root字段表示分包路径,也就是指定分包中页面所处的文件夹路径;pages字段可选,如果不指定pages,则表示该分包仅仅包含组件和其他资源文件,不包含页面。

二、分包示例

1. 在app.json文件中添加subpackages字段:

```javascript

{

"pages": [

"pages/index/index",

],

"subPackages": [

{

"name": "package1",

"root": "pages/package1/",

"pages": [

"package1-page1"

]

},

{

"name": "package2",

"root": "pages/package2/",

"pages": [

"package2-page1"

]

}

],

"tabBar": {

"list": [

{

"pagePath": "pages/index/index",

"text": "首页"

},

{

"pagePath": "pages/package1/package1-page1",

"text": "第一个分包"

},

{

"pagePath": "pages/package2/package2-page1",

"text": "第二个分包"

}

]

}

}

```

上述代码中我们可以看到:

- 三个文件夹(一个根文件夹,两个分包)

- 文件夹名包含多个单词(需用连字符隔开)

- 每个分包中只有一个页面

- 分包包含的页面路径,最终打包时会被合并至分包对应的目录

2. 打开微信开发者工具,可以在工具栏中找到“分包分析”按钮,点击后可以查看应用在各个分包之间的资源大小和依赖关系。

![image](https://cdn.nlark.com/yuque/0/2021/png/10872165/1613063421692-0d70ade6-3b4e-4d3a-8a8c-a99b068b0f13.png#align=left&display=inline&height=212&margin=%5Bobject%20Object%5D&name=image.png&originHeight=212&originWidth=781&size=16516&status=done&style=none&width=781)

在上述分析结果中,我们可以看到wxss、js、wxs、json等文件按照各个分包进行资源拆分,根据分析结果,我们可以对分包做一些优化和调整,例如单独拆出一些公共组件放到公共分包中,以此减小分包的大小。

三、注意事项

1. 分包名称不能重复。当分包名相同时,后面的分包会覆盖前一个分包。

2. 分包路径必须以/结尾,指定路径时,不建议使用../的相对路径。

3. 分包中的文件不能超过1MB,否则无法预加载。对于超过1MB的文件,建议使用动态加载的方式。

4. 注意分包的文件夹结构,确保不同分包中的文件不会有路径冲突。

总之,Uniapp中的分包机制,可以方便地将大型应用的代码拆分成多个小包,从而减小单个包的大小,提高小程序的启动速度和用户体验。


相关知识:
百度智能小程序给开发者送大红包
百度智能小程序给开发者送大红包是一个激励开发者参与和贡献百度智能小程序生态的活动。本文将详细介绍该活动的原理和具体细节。首先,为了了解百度智能小程序给开发者送大红包的原理,我们需要先了解什么是百度智能小程序。百度智能小程序是百度推出的一种轻量级应用开发框架
2023-08-23
百度小程序开发者怎么删除
百度小程序是一种基于百度生态的应用程序开发模式,通过该模式可以开发出在百度 App 内运行的小程序。如果你是一个百度小程序开发者,并且想要删除某个小程序,我将为你提供详细的介绍和步骤。删除百度小程序需要在百度开放平台进行操作。下面是删除小程序的具体步骤:1
2023-08-23
安徽幼儿托管班小程序开发方案怎么写
随着社会的发展,人们越来越注重孩子的早期教育,幼儿托管班也成为了一个备受关注的领域。针对幼儿托管班的管理问题,开发一款小程序,不仅能够方便家长了解孩子的情况,也有利于托管班的管理操作和数据分析。本文将介绍安徽幼儿托管班小程序的开发方案。一、小程序架构安徽幼
2023-08-09
安卓小程序开发技巧和方法
安卓小程序是一种基于原生Android应用程序的可轻量化的Web APP。它的应用场景主要是在需要快速开发小型应用的情况下,由于不需要像传统的应用一样下载安装,所以可以省去很多时间和流量成本。以下是一些安卓小程序开发的技巧和方法:1. 了解小程序的原理安卓
2023-08-09
xmind小程序开发教程
XMind是一款流行的思维导图软件,它不仅在PC端和移动端都有应用,还具有丰富的功能与定制化。很多用户希望通过XMind小程序来获取思维导图的功能,而XMind小程序的开发需要掌握一些前端技术和XMind的API。下面是一个XMind小程序开发的大致流程和
2023-08-09
wifi贴小程序开发
Wi-Fi贴是指一种能够帮助用户快速连接无线网络的小型装置。用户只需要将Wi-Fi贴贴到路由器上,通过扫描Wi-Fi贴上的二维码就可以自动将手机或电脑连接到无线网络上。目前,一些厂家已经推出了可以使用微信小程序来配对Wi-Fi贴并连接无线网络的功能。那么,
2023-08-09
qq小程序开发者平台为何发布不了
QQ小程序是由腾讯公司推出的一种轻量级应用,它具有小巧、易用、拓展性强等特点。同时,QQ小程序开发者平台支持开发者上传和发布小程序,但是很多开发者反馈无法发布,这是为什么呢?首先,可能是平台限制导致的。开发者在进行发布QQ小程序前,需要完成一些必要的审核和
2023-08-09
jfinal开发小程序后台
JFinal是一款基于Java语言的轻量级Web开发框架,其非常适合于开发小型的Web应用程序。除此之外,JFinal框架也可以支持开发小程序后台。为了开发小程序后台,需要首先要明确小程序和后台的概念。小程序是微信推出的一种轻应用程序,用户可以在微信中直接
2023-08-09
excel自动计算小程序开发费用
Excel是一个非常实用的电子表格软件,能够帮助用户轻松地进行数据管理和计算。在工作中,大量的数据需要手动进行计算,这既费时又容易出错,给工作带来了不便。因此,为了提高效率和减少错误,很多人都希望可以通过一些小工具来实现自动计算。针对这一问题,可以通过开发
2023-08-09
微信小程序开发工具是免费吗
微信小程序开发工具是免费的。微信小程序开发工具是一款可视化的IDE,为微信小程序提供开发、调试、预览、打包的功能,而且完全免费,不会向开发者收取费用。这个工具提供了丰富的代码库和可视化的操作界面,极大地简化了开发小程序的难度和门槛。微信小程序开发工具的主要
2023-05-26
微信小程序开发工具伪类
微信小程序开发工具是开发微信小程序的集成开发环境,其内置了很多有用的功能和工具,以帮助开发者高效地完成小程序的开发。其中,伪类是开发工具中的一个很重要的功能,可以帮助开发者更加方便地对小程序进行样式的调整和优化。伪类是CSS中重要的一种选择器,定义了一些无
2023-05-26
钉钉小程序开发工具下载安装
钉钉小程序是阿里巴巴旗下产品钉钉推出的一款应用开发平台,类似于微信小程序和支付宝小程序。通过钉钉小程序开发平台,用户可以自由创建和发布小程序,用于企业内部应用或向外展示。一、下载安装钉钉开发工具使用钉钉小程序开发工具前,需要先下载安装。钉钉小程序开发工具目
2023-05-22