我的编程空间,编程开发者的网络收藏夹
学习永远不晚

webpack中的optimization怎么配置

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

webpack中的optimization怎么配置

本篇内容主要讲解“webpack中的optimization怎么配置”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“webpack中的optimization怎么配置”吧!

webpack配置optimization

  • minimizer

  • runtimeChunk

  • noEmitOnErrors

  • splitChunks

主要就是根据不同的策略来分割打包出来的bundle。

本人项目中splitChunks配置如下:

module.exports = {                    chainWebpack(config) {                        config.when(process.env.NODE_ENV != 'development',                            config => {                                config.optimization.splitChunks({                                    chunks: 'all',                                    cacheGroups: {                                        // 第三方组件                                        libs: {                                            指定chunks名称                                            name: 'chunk-libs',                                            //符合组的要求就给构建venders                                            test: /[\\/]node_modules[\\/]/,                                            //priority:优先级:数字越大优先级越高,因为默认值为0,所以自定义的一般是负数形式,决定cacheGroups中相同条件下每个组执行的优先顺序。                                            priority: 10,                                            // 仅限于最初依赖的第三方                                            chunks: 'initial'                                        },                                        elementUI: {                                            // 将elementUI拆分为单个包                                            name: 'chunk-elementUI',                                            // 重量需要大于libs和app,否则将打包到libs或app中                                            priority: 20,                                            // 为了适应cnpm                                            test: /[\\/]node_modules[\\/]_?element-ui(.*)/                                        },                                        //公共组件                                        commons: {                                            name: 'chunk-commons',                                            // can customize your rules                                            test: resolve('class="lazy" data-src/components'),                                            minChunks: 3,                                            priority: 30,                                            //这个的作用是当前的chunk如果包含了从main里面分离出来的模块,则重用这个模块,这样的问题是会影响chunk的名称。                                            reuseExistingChunk: true,                                            //最大初始化加载次数,一个入口文件可以并行加载的最大文件数量,默认3                                            maxInitialRequests: 3,                                            //表示在分离前的最小模块大小,默认为0,最小为30000                                            minSize: 0                                        },                                        echarts: { // split echarts libs                                            name: 'chunk-echarts',                                            test: /[\\/]node_modules[\\/]_?echarts(.*)/,                                            priority: 40,                                            chunks: 'async',                                            reuseExistingChunk: true                                        },                                        monaco: { // split monaco libs                                            name: 'chunk-monaco',                                            test: /[\\/]node_modules[\\/]_?monaco(.*)/,                                            priority: 40,                                            chunks: 'async',                                            reuseExistingChunk: true                                        },                                        'project-components': { // split project libs                                            name: 'chunk-project-components',                                            test: resolve('class="lazy" data-src/views/project'),                                            priority: 50,                                            chunks: 'async',                                            reuseExistingChunk: true                                        },                                        'teachers-components': { // split teacher libs                                            name: 'chunk-teachers-components',                                            test: resolve('class="lazy" data-src/views/teachers'),                                            priority: 60,                                            chunks: 'async',                                            reuseExistingChunk: true                                        },                                        'utils': { // split utils libs                                            name: 'chunk-utils',                                            test: resolve('class="lazy" data-src/utils'),                                            priority: 70,                                            chunks: 'async',                                            reuseExistingChunk: true                                        },                                    }                                })                            })                    }                }

分析工具:webpack-bundle-analyzer

  • 安装

npm i --save-dev webpack-bundle-analyzer

  • 配置

 config.plugin('BundleAnalyzerPlugin').use(BundleAnalyzerPlugin).tap(() => [      {        rel: 'BundleAnalyzerPlugin',        analyzerMode: 'server', // 'server': 启动端口服务;'static': 生成 report.html;'disabled': 配合 generateStatsFile 使用;        generateStatsFile: false, // 是否生成stats.json文件        analyzerHost: '127.0.0.1',        analyzerPort: '8667',        reportFilename: 'report.html',        defaultSizes: 'parsed',        openAnalyzer: false,        statsFilename: 'stats.json',        statsOptions: null,        excludeAssets: null      }

运行

npm run build 或者 npm run dev

访问

http://127.0.0.1:8877

扩展:webpack中module package bundle chunk详细讲解

  • module 模块 写一个commonjs 或者amd规范的包就叫module

  • package 是所有module构成的,它是一个整体的概念,整个项目就是一个package,它可能是commonjs或者amd规范的包

  • bundle是webpack打包的结果 所有的module都打包成一个文件 (module集合)

  • chunk bundle是入口bundle,异步加载一个模块,是需要运行时去处理的,获取的过程就是一个代码块即chunk;由bundle获取的包为chunk

到此,相信大家对“webpack中的optimization怎么配置”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

webpack中的optimization怎么配置

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

webpack中的optimization怎么配置

本篇内容主要讲解“webpack中的optimization怎么配置”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“webpack中的optimization怎么配置”吧!webpack配置opt
2023-07-05

webpack中的optimization配置示例详解

这篇文章主要介绍了webpack中的optimization配置详解,主要就是根据不同的策略来分割打包出来的bundle,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-02-23

Angular10怎么配置webpack打包

小编给大家分享一下Angular10怎么配置webpack打包,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!对于 Angular 项目,推荐使用 angular-
2023-06-14

webpack中的代理配置方法

这篇文章主要介绍了webpack中的代理配置方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇webpack中的代理配置方法文章都会有所收获,下面我们一起来看看吧。作用:1.解决开发环境跨域问题(不用再去配置n
2023-07-02

vue项目怎么实现webpack配置代理

本文小编为大家详细介绍“vue项目怎么实现webpack配置代理”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue项目怎么实现webpack配置代理”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。webpack
2023-06-29

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录