【uniapp开发微信小程序分包异步化的实践 】

背景

相信很多开发微信小程序的都遇到过小程序主包限制2M的问题。只要主包超过2M就会导致无法发布小程序。前提是你已经完成了小程序的基本分包。当小程序功能复杂,且主包中引入了大体积的第三方库,此时删减代码量效果微乎其微。因此重点是:在不占用主包大小的情况下,依然可以使用这些库。本文以mqtt为例。

查看主包大小构成

安装webpack-bundle-analyzer 。并在vue.config.js下加入如下配置。当你成功使用HbuildX启动小程序时,浏览器会自动打开一个名为 http://127.0.0.1:8888/ 的本地服务。可以清楚主包体积结构。我看出mqtt.js占用主包较大,所以我们优先选择优化体积较大的包。

js 复制代码
//vue.config.js
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
module.exports = {
  configureWebpack: { //直接使用copy官网到代码运行HbuilderX 会报错,在这里加了一层 //configureWebpack
    plugins: [
      new BundleAnalyzerPlugin()
    ]
  }
}

1、配置分包

首先在pages.json下配置mqtt的分包,然后在你的根目录下创建一个空的index.vue (否则会报错)和mqtt.js。 mqtt.js中放入mqtt.js的源码。

js 复制代码
"subPackages": [
		{
			"root": "packageMqtt",
			"name": "packageMqtt",
			"pages": [
				{
					"path": "index"
				}
			]
		}
	]

2、使用copy-webpack-plugin

安装copy-webpack-plugin,在vue.config.js中使用一下。

js 复制代码
// vue.config.js
const path = require('path'); // Import the path module
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
const CopyWebpackPlugin = require('copy-webpack-plugin')
module.exports = {
  configureWebpack: { //直接使用copy官网到代码运行HbuilderX 会报错,在这里加了一层 
    plugins: [
      new BundleAnalyzerPlugin(),
      new CopyWebpackPlugin([
        {
          from: path.join(__dirname, 'packageMqtt'),
          to: path.join(__dirname, 'unpackage/dist', process.env.NODE_ENV === 'production' ? 'build' : 'dev', process.env.UNI_PLATFORM, 'packageMqtt'),
        }
      ])
    ]
  }
}

3、修改主包中引入mqtt的方式

注释掉 import mqtt from "@/utils/mqtt.js"

js 复制代码
<script>
// import mqtt from "@/utils/mqtt.js";
let mqtt = null;
export default {
  data() {},
  methods: {
  //添加一个异步化加载mqttJs的方法
    getMqttAsync(cb) {
      if (mqtt) {
        cb(mqtt);
      } else {
        __non_webpack_require__ &&
          __non_webpack_require__(
            "../packageMqtt/mqtt.js",
            (res) => {
              // 这里打印一下 mqtt.js 的源码
              console.log("mqttJs", res);
              mqtt = res;
              cb(mqtt);
            },
            ({ mod, errMsg }) => {
              console.error(`分包异步化报错: ${mod}=================${errMsg}`);
            }
          );
      }
    },
  },
  async onLaunch() {//onReady ready 选择合适的hook 异步化加载mqtt
    this.getMqttAsync((mqttjs) => {
      mqtt = mqttjs;
    });
  },
};
</script>

跑一下看看效果,成功拿到mqtt实例。

再看一下主包结构

成功将主包大小1.76M => 1.4M 。四舍五入约0.4M。至此完成了第三方库的分包异步化引入。

4、总结

跳过主包打包mqtt的流程。然后通过copy-webpack-plugin将mqtt.js复制进dist文件下对应的分包文件夹内实现了分包异步化。成功优化了小程序主包的体积大小

相关推荐
StarChainTech1 分钟前
先享后付,正在悄悄改变电商的“信任游戏”
大数据·人工智能·游戏·微信小程序·小程序·软件需求
西洼工作室15 小时前
个人开发者接入阿里云号码认证服务AliCloud-NirvanaPns实现一键登录
python·阿里云·uni-app·全栈·认证授权
2501_9160088921 小时前
ChatGPT前端开发学习指南:Visual Studio Code与谷歌浏览器安装配置详解
ide·vscode·ios·小程序·uni-app·编辑器·iphone
2501_915909061 天前
完整指南:如何将iOS应用上架到App Store
android·ios·小程序·https·uni-app·iphone·webview
無名路人2 天前
uniApp 小程序 vue3 app.vue静默登录其他页面等待登录完成方式二
前端·微信小程序·ai编程
xiangxiongfly9152 天前
uni-app 组件总结
前端·javascript·uni-app
2501_915918412 天前
iOS性能数据监控:从概念到工具实践,让应用运行更流畅
android·macos·ios·小程序·uni-app·cocoa·iphone
silvia_Anne2 天前
微信小程序(组件通讯和全局数据共享)
微信小程序·小程序
i220818 Faiz Ul2 天前
个人健康系统|健康管理|基于java+Android+微信小程序的个人健康系统设计与实现(源码+数据库+文档)
android·java·vue.js·spring boot·微信小程序·毕设·个人健康系统
2501_915909063 天前
全面解析前端开发中常用的浏览器调试工具及其使用场景
android·ios·小程序·https·uni-app·iphone·webview