Webpack 通过SplitChunksPlugin实现包拆分

news/2024/9/25 23:20:19/
  1. Entry Points:你可以通过配置多个入口来实现,Webpack 会根据依赖关系自动拆分成多个 chunk。这是一个相对简单的方式,但是可能会导致一些重复代码。

  2. SplitChunksPlugin:这是一个更加强大的拆包工具,它会分析模块间的依赖关系,将多个模块公共的部分提取到单独的 chunk 中。
    SplitChunksPlugin 的配置选项用于优化代码拆分,允许更细粒度的控制代码拆分的行为。以下是一些主要的配置选项:

    (1) cacheGroups: 这是 SplitChunksPlugin 最重要的配置选项之一,可以用来定义如何将模块分配到 cache group 中(缓存组)。你可以为每个 cache group 指定一个特定的测试函数、优先级、重用已有的 chunk 等等。

    (2) chunks: 用于控制本插件影响哪些 chunk,可选值为 “initial”(只影响初始 chunk),“async”(只影响异步 chunk),“all”(同时影响上述两者)。

    (3)minSize: 用于控制拆分出的新 chunk 的最小大小,单位为字节。默认值为 30000。

    (4) minChunks: 用于控制一个模块被多少个 chunk 共享才会被拆分出来,默认值为 1。

    (5) maxAsyncRequests: 控制同时加载的异步请求数量的最大值,默认值为 6。

    (6) maxInitialRequests: 控制初始页面加载时的最大请求数量,默认值为 4。

    (7) automaticNameDelimiter: 用于生成 chunk 名称时的分隔符,默认值为 ‘~’。

    (8) name: 可以是一个返回 chunk 名称的函数,或者是一个固定的 chunk 名称。如果不提供,则会根据 chunk 的包和选项自动生成一个。

每个选项都可以在你的 webpack 配置文件的 optimization.splitChunks 属性下设置。这样你就可以根据你自己的需求微调代码拆分的行为,以优化你的代码包的大小和加载性能。
要配置 SplitChunksPlugin,你需要在你的 webpack 配置中添加 optimization.splitChunks 配置。下面是一个简单的示例:

module.exports = {//...optimization: {splitChunks: {chunks: 'all',},},
};

在这个配置文件中,splitChunks.chunks 选项被设置为 ‘all’, 表示所有的 chunks,包括同步和异步导入的都会被分包。

要通过SplitChunksPlugin将从node_modules目录导入的模块合并到一个名为’Vendors’的chunk中,你可以通过修改webpack的配置文件中的分包策略来实现。以下是一个例子:

module.exports = {//...optimization: {splitChunks: {cacheGroups: {vendor: {test: /[\\/]node_modules[\\/]/,name: 'vendors',chunks: 'all',},},},},
};

在这个配置中,我们创建了一个名为’vendor’的缓存组,它会匹配所有从node_modules目录导入的模块(由test: /[\\/]node_modules[\\/]/这行定义)。然后,为这些模块创建一个名为’vendors’的新chunk(由name: 'vendors'这行定义)。

此外,chunks: 'all'告诉webpack,无论模块是同步加载还是异步加载,都应该选择并放入’vendors’这个chunk中。分包策略可以在这里自行定义,chunks可以设置为all, async, initial其中的一个,分别对应全部模块,异步模块,初始加载模块。

这样,在打包的时候,Webpack就会将所有从node_modules目录导入的模块打包到一个单独的’vendors’chunk中。

3.如果你想要对一个或多个特定的包(例如前端依赖的 abc 几个体积较大的包)进行更进一步的控制,你可以使用 cacheGroups 选项来创建一个特定的规则:

module.exports = {//...optimization: {splitChunks: {cacheGroups: {vendor: {test: /[\/]node_modules[\/](a|b|c)[\/]/,name: 'vendors',chunks: 'all',},},},},
};

在这个配置中,所有从 node_modules 目录下的 a, b, c 三个包导入的模块会被合并到一个单独的 vendors chunk 中。

以上就是文章全部内容了,如果喜欢这篇文章的话,还希望三连支持一下,感谢!


http://www.ppmy.cn/news/1466568.html

相关文章

mysql中子查询的语法和执行过程

大家好。我们在日常开发过程中,肯定都经常用到了子查询。今天我们就来聊一下mysql中子查询的一些语法以及子查询的执行过程。 一、子查询的语法 首先在开讲之前,我们先创建t1、t2两张表,并分别在表中插入三条数据,方便我们下面内…

【Paddle2ONNX】为 Paddle2ONNX 升级自适应ONNX IR Version功能

1 简介 最近在浏览 Paddle2ONNX 的 Issues 时,我发现有用户需要让 Paddle2ONNX 支持导出的 ONNX 模型根据opset版本自适应 ONNX IR 版本,于是我动手添加了这个功能。 能否指定 IR representation的版本 Issue #1248 PaddlePaddle/Paddle2ONNX 2 什么…

git随记

git status 查看文件状态 git status -s 比较简洁的查看文件状态。如下代表此文件是新建的,没有被git跟踪的文件: $ git status -s ?? abc.txtgit add abc.txt 将abc添加到暂存区。后再次git status -s $ git status -s A abc.txtgit reset 将暂存…

在AWR中进行版图仿真、网格剖分、电流密度可视化---以威尔金森功分器的设计为例

在AWR中进行版图仿真、网格剖分、电流密度可视化—以威尔金森功分器的设计为例 生活不易,喵喵叹气。马上就要上班了,公司的ADS的版权紧缺,主要用的软件都是NI 的AWR,只能趁着现在没事做先学习一下子了,希望不要裁我。…

Spring Boot 整合开源 Tess4J库 实现OCR图片文字识别

😄 19年之后由于某些原因断更了三年,23年重新扬帆起航,推出更多优质博文,希望大家多多支持~ 🌷 古之立大事者,不惟有超世之才,亦必有坚忍不拔之志 🎐 个人CSND主页——Mi…

数据结构——B树代码

#define _CRT_SECURE_NO_WARNINGS #pragma warning(disable:6031) #include<stdio.h> #include<stdlib.h> #include<bits/stdc.h> using namespace std; /*B树&#xff1a; */#define m 3 //B树的阶 #define minn (m 1) / 2 - 1//非根节点关键字个数的下限…

基于java的CRM客户关系管理系统(五)

目录 第五章 系统的详细设计与实现 5.1 持久层设计 5.1.1 创建关系映射 5.1.2 与数据库的连接 5.1.3 Hibernate的ORM映射 5.1.4 Struts的配置文件 5.1.5 Spring 的配置文件 5.1.6 DAO层设计 5.2 逻辑业务层设计 5.2.1 业务逻辑类的实现 前面内容请移步 基于java的C…

【机器学习】探索未来科技的前沿:人工智能、机器学习与大模型

文章目录 引言一、人工智能&#xff1a;从概念到现实1.1 人工智能的定义1.2 人工智能的发展历史1.3 人工智能的分类1.4 人工智能的应用 二、机器学习&#xff1a;人工智能的核心技术2.1 机器学习的定义2.2 机器学习的分类2.3 机器学习的实现原理2.4 机器学习的应用2.5 机器学习…