基于uni-app的微信小程序之分包

2023-05-14,,

作者:故事我忘了
个人微信公众号:程序猿的月光宝盒


目录
0. 缘由
1. 关于分包
1.0 这是 官方文档
1.1 注意事项
2.使用方法
2.1 首先你得有个uniapp的微信小程序项目
2.2 在pages同级创建分包
2.3 pages.json配置
2.4 然后呢,官网支持了 分包优化
2.5 怎么跳转呢?
2.6 然后重启微信开发工具运行

0. 缘由

​ 最近工作在接触uni-app,用它来开发微信小程序,也是第一次接触,找了很久,还有大佬用自己写的函数做的,俺觉得我不会也不配,刚好看到下面评论是官方也支持了,所以就用官方的了,这里记录一下

1. 关于分包

​ 好像是规定小程序不能超过2M,一旦超过就需要分包,因为是公司项目,肯定超过,所以就做个演示,权当记录吧

1.0 这是 官方文档

1.1 注意事项

    subPackages 里的pages的路径是 root 下的相对路径,不是全路径。
    微信小程序每个分包的大小是2M,总体积一共不能超过16M。
    百度小程序每个分包的大小是2M,总体积一共不能超过8M。
    支付宝小程序每个分包的大小是2M,总体积一共不能超过4M。
    QQ小程序每个分包的大小是2M,总体积一共不能超过24M。
    分包下支持独立的 static 目录,用来对静态资源进行分包。
    uni-app内支持对微信小程序、QQ小程序、百度小程序分包优化,即将静态资源或者js文件放入分包内不占用主包大小。详情请参考:关于分包优化的说明
    针对vendor.js过大的情况可以使用运行时压缩代码
    HBuilderX创建的项目勾选运行-->运行到小程序模拟器-->运行时是否压缩代码
    cli创建的项目可以在pacakge.json中添加参数--minimize,示例:"dev:mp-weixin": "cross-env NODE_ENV=development UNI_PLATFORM=mp-weixin vue-cli-service uni-build --watch --minimize"

2.使用方法

2.1 首先你得有个uniapp的微信小程序项目

​ 这里假设你有了,原始项目结构

​ 用微信开发工具打开的样子,没有分包之前

2.2 在pages同级创建分包

2.3 pages.json配置

2.4 然后呢,官网支持了 分包优化

在对应平台的配置下添加"optimization":{"subPackages":true}开启分包优化
目前只支持mp-weixinmp-qqmp-baidu的分包优化
分包优化具体逻辑:
静态文件:分包下支持 static 等静态资源拷贝,即分包目录内放置的静态资源不会被打包到主包中,也不可在主包中使用
js文件:当某个 js 仅被一个分包引用时,该 js 会被打包到该分包内,否则仍打到主包(即被主包引用,或被超过 1 个分包引用)
自定义组件:若某个自定义组件仅被一个分包引用时,且未放入到分包内,编译时会输出提示信息

我的理解呢就是,既然你分包了功能模块,那相应的静态资源你得分吧,用图片的时候直接是分包下的路径,这才是个完整的分包.

这里我以微信小程序为例,

2.5 怎么跳转呢?

在需要点击跳转的地方就好啦

        uni.navigateTo({
url: '/myPackageA/pages/piece/piece'
})

2.6 然后重启微信开发工具运行

可以看到已经分包成功

最后上个演示GIF 叭

基于uni-app的微信小程序之分包的相关教程结束。

《基于uni-app的微信小程序之分包.doc》

下载本文的Word格式文档,以方便收藏与打印。