Uniapp小程序端打包优化实践

背景描述:

在我们最近开发的一款基于uniapp的小程序项目中,随着功能的不断丰富和完善,发现小程序包体积逐渐增大,加载速度也受到了明显影响。为了提升用户体验,团队决定对小程序进行一系列打包优化。


项目优化点:

  1. 代码精简与重构
    我们首先对项目进行全面梳理,通过ESLint等工具检查并删除了未使用的变量、函数和组件。同时,对冗余逻辑进行了合并和简化,并采用更高效的编码方式,例如用解构赋值替代传统的变量定义。

  2. 条件编译与按需加载
    对于不同平台的小程序,我们充分利用uniapp的条件编译特性,只引入目标平台所需的API和组件。此外,对于大型业务模块或不常使用的功能组件,采用了异步加载策略,避免一次性加载所有内容导致主包过大。

  3. 第三方库优化
    项目中使用了一些第三方库,比如axios用于网络请求,UI库等。通过Webpack的Tree Shaking功能,剔除了库中未使用的部分。同时,对于非核心依赖,考虑使用CDN引用或者将其拆分至分包中。

  4. 资源优化
    所有图片资源都经过压缩处理,确保在不影响视觉效果的前提下减小文件大小。并且针对一些不常用的大图资源,采取了懒加载策略。另外,考虑到WebP格式的高效率,将部分图片转换为WebP格式。

  5. 分包策略
    鉴于主包体积接近微信小程序2MB的限制,我们将部分非首屏展示的功能模块(如用户中心、设置页等)迁移到子包中,实现按需加载,显著减少了首次加载时的数据传输量。

  6. 构建配置调整
    在HBuilderX中,我们开启了JavaScript代码压缩选项,将ES6代码转译为兼容性更好的ES5代码,并且移除console.log等调试语句以进一步减少代码体积。

  7. GZip压缩
    联系服务器运维团队,在服务器端开启GZip压缩,有效降低了实际传输过程中静态资源的大小。

经过这一系列优化措施,我们的小程序包体积成功从原来的近3MB降低到约1.5MB,加载速度有了显著提升,用户反馈页面打开更加流畅,整体体验得到了极大改善。这个案例充分展示了在uniapp开发小程序时,细致深入的打包优化工作的重要性。


实际项目优化

优化前分析

在这里插入图片描述
在这里插入图片描述
以上图片中可以看到主包很大 , 原因是 uviewUI库 和 框架依赖问题导致

优化项目

开启 hbuilder 上传代码压缩在这里插入图片描述

开启运行是否压缩代码
在这里插入图片描述

压缩后还是大于2MB
在这里插入图片描述

可以看出uviewUI库还是有点大,图片静态资源可以放到服务器上,使用网络图片
在这里插入图片描述

再次优化

减少在uni.scss 中的样式。uni.scss的样式会导入uview每一个组件的scss中在这里插入图片描述

尽量别去动 theme.scss里面的样式,这也会导致uview每一个组件的添加了scss样式
所以我们把这里的样式去掉,在看一下
在这里插入图片描述

可以看到优化成功
在这里插入图片描述

这里我们可以看到uviewUI 小了很多 1.03MB => 138 KB
在这里插入图片描述

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
uni-app小程序打包流程如下: 1. 首先,运行项目并点击发行 - 小程序/网站 - 设置小程序/网站名字/appid/域名。这一步是为了配置小程序的相关信息,包括小程序的名称、AppID、域名等。\[1\] 2. 打包成功后,可以在dist - build文件夹下找到对应平台的打包文件。对于小程序,可以在该文件夹下找到小程序打包文件。\[1\] 3. 如果需要在多个平台上发布小程序,可以使用uni-app开发多项目的特性。uni-app支持通过HBuilderX可视化界面和vue-cli命令行两种方式创建项目。在HBuilderX可视化界面中创建项目后,可以选择多个平台进行打包,包括小程序、H5和App。\[2\] 4. 对于Android平台,最终生成的apk文件可以通过聊天工具发送到安卓手机上进行安装和使用。也可以将apk文件上传到各大安卓应用市场,供用户下载。另外,还可以自己开发一个发布页,将安卓apk放到项目中,用户点击后直接下载到手机上。\[3\] 总结起来,uni-app小程序打包流程包括配置小程序信息、打包生成小程序文件、选择多个平台进行打包,以及将生成的文件安装到手机或上传到应用市场供用户下载。 #### 引用[.reference_title] - *1* *2* *3* [用uniapp开发打包应用完整指南](https://blog.csdn.net/xjbx/article/details/128114077)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

织_网

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值