前端打包优化相关 Webpack
前端打包优化相关 Webpack
打包时间的优化(基于 Vue CLI 4 + Webpack 5)
1. Webpack 配置减少打包时间
1.1 对 JS 配置:排除 node_modules 和 src 中的打包内容
在开发环境下,修改 Webpack 的 JS 规则,排除 /node_modules 和 src 目录中的 JavaScript 文件。这意味着 node_modules 和 src 目录中的 JavaScript 文件不会经过该规则定义的加载器处理(如 Babel 转译、ESLint 检查等)。
chainWebpack: (config) => {// //编译时将项目的版本号作为一个全局常量ProjectVersion注入到代码中config.plugin('define').tap((args) => {args[0].ProjectVersion = JSON.stringify(ProjectVersion);return args;});// 判断当前环境是否为开发环境if (process.env.NODE_ENV === 'development') {// 配置模块规则config.module.rule('js').exclude.add(resolve('/node_modules')).add(resolve('src'));}
};
1.2 创建 DLL 配置文件,对第三方插件提前打包到本地
1.2.1 配置打包 DLL 文件
const path = require('path');
const webpack = require('webpack');module.exports = {mode: 'production', // 设置为生产模式entry: {// 将第三方库分组打包vue: ['vue', 'vue-router', 'vuex'],elementUI: ['element-ui'],axios: ['axios'],lodash: ['lodash'],},output: {path: path.resolve(__dirname, 'dll'), // 输出目录filename: '[name].dll.js', // 输出文件名library: '[name]_library', // 全局变量名},plugins: [// 生成 manifest 文件new webpack.DllPlugin({name: '[name]_library', // 需要与 output.library 一致path: path.resolve(__dirname, 'dll/[name]-manifest.json'), // manifest 文件路径}),],
};
执行命令生成 DLL 文件:
npx webpack --config webpack.dll.config.js
1.2.2 配置打包文件使用 DLL 文件并插入到模板中
configureWebpack: (config) => {config.plugins.push(// 引入分片的 DLL 文件new webpack.DllReferencePlugin({manifest: require(path.resolve(__dirname, 'public/dll/vue-manifest.json')),}),new webpack.DllReferencePlugin({manifest: require(path.resolve(__dirname, 'public/dll/axios-manifest.json')),}),new webpack.DllReferencePlugin({manifest: require(path.resolve(__dirname, 'public/dll/elementGui-manifest.json')),}),new webpack.DllReferencePlugin({manifest: require(path.resolve(__dirname, 'public/dll/vueBaiduMap-manifest.json')),}),new webpack.DllReferencePlugin({manifest: require(path.resolve(__dirname, 'public/dll/glodonTinymce-manifest.json')),}),new webpack.DllReferencePlugin({manifest: require(path.resolve(__dirname, 'public/dll/elementChinaAreaData-manifest.json')),}),new webpack.DllReferencePlugin({manifest: require(path.resolve(__dirname, 'public/dll/mintUi-manifest.json')),}),// 将分片的 DLL 文件添加到 HTML 模板中new AddAssetHtmlPlugin([{filepath: path.resolve(__dirname, 'public/dll/vue.dll.js'),publicPath: process.env.VUE_APP_PUBLIC_PATH, // 根据项目路径调整},{filepath: path.resolve(__dirname, 'public/dll/axios.dll.js'),publicPath: process.env.VUE_APP_PUBLIC_PATH,},{filepath: path.resolve(__dirname, 'public/dll/vueBaiduMap.dll.js'),publicPath: process.env.VUE_APP_PUBLIC_PATH,},{filepath: path.resolve(__dirname, 'public/dll/elementGui.dll.js'),publicPath: process.env.VUE_APP_PUBLIC_PATH,},{filepath: path.resolve(__dirname, 'public/dll/glodonTinymce.dll.js'),publicPath: process.env.VUE_APP_PUBLIC_PATH,},{filepath: path.resolve(__dirname, 'public/dll/elementChinaAreaData.dll.js'),publicPath: process.env.VUE_APP_PUBLIC_PATH,},{filepath: path.resolve(__dirname, 'public/dll/mintUi.dll.js'),publicPath: process.env.VUE_APP_PUBLIC_PATH,},]));
},
1.3 开启多线程打包
使用 thread-loader 可能会达不到效果,因为开启多线程也需要时间。
// 开启多线程打包
config.module.rule('vue').use('thread-loader').loader('thread-loader').tap(() => {return {workers: os.cpus().length,};}).before('vue-loader');
1.4 删除无用的插件配置,去掉 sourceMap
chainWebpack: (config) => {// 删除一些无用插件config.plugins.delete('friendly-errors');config.devtool = false; // eval|none source-map hidden-source-map // 不生成 sourceMap 源代码,减少体积,加快打包速度
};
1.5 删除 console.log(生产环境),配置压缩 JS 和 CSS
// vue.config.js
const TerserPlugin = require('terser-webpack-plugin');
const CssMinimizerPlugin = require('css-minimizer-webpack-plugin');module.exports = {configureWebpack: {optimization: {minimize: true, // 启用压缩minimizer: [new TerserPlugin({terserOptions: {compress: {drop_console: true, // 删除 console.logpure_funcs: ['console.log'], // 只删除 console.log},format: {comments: false, // 删除注释},},extractComments: false, // 不提取注释到单独文件}),new CssMinimizerPlugin({minimizerOptions: {preset: ['default',{discardComments: { removeAll: true }, // 删除所有注释},],},}),],},},
};
2. 如何减少 Webpack 打包体积
2.1 按需加载
按需加载可以减少初始加载的代码量,提升页面加载速度。
2.2 Scope Hoisting
Scope Hoisting 会分析出模块之间的依赖关系,尽可能将打包出来的模块合并到一个函数中,减少函数声明和闭包的开销。
2.3 Tree Shaking
Tree Shaking 会去除没有引用的代码,减少打包体积。
通过以上优化措施,可以有效减少 Webpack 打包时间和体积,提升项目性能。
相关文章:
前端打包优化相关 Webpack
前端打包优化相关 Webpack 打包时间的优化(基于 Vue CLI 4 Webpack 5) 1. Webpack 配置减少打包时间 1.1 对 JS 配置:排除 node_modules 和 src 中的打包内容 在开发环境下,修改 Webpack 的 JS 规则,排除 /node_m…...
抓包分析工具介绍
什么是抓包分析工具? 抓包分析工具,也称为网络数据包嗅探器或协议分析器,用于捕获和检查网络上传输的数据包。这些数据包包含了网络通信的详细信息,例如请求的资源、服务器的响应、HTTP 头信息、传输的数据内容等等。通过分析这些…...
Linux第一课
一、Linux背景与发展 1. 发展史 1968年,研究人员开发了Multics操作系统,为后续发展奠定了基础。 1969−1970年,Ken Thompson和Dennis Ritchie在Multics基础上开发了UNIX系统。 1991年,Linus Torvalds发布了Linux操作系统&#…...
2025/3/8 第 27 场 蓝桥入门赛 题解
1. 38红包【算法赛】 签到题: 算倍数就行了 #include <bits/stdc.h> using namespace std; int main() {int ans0;for(int i1;i<2025;i){if(i % 3 0)ans;else if(i % 8 0)ans;else if(i % 38 0)ans;}cout<<ans<<endl;return 0; } 2. 祝福…...
使用Node.js从零搭建DeepSeek本地部署(Express框架、Ollama)
目录 1.安装Node.js和npm2.初始化项目3.安装Ollama4.下载DeepSeek模型5.创建Node.js服务器6.运行服务器7.Web UI对话-Chrome插件-Page Assist 1.安装Node.js和npm 首先确保我们机器上已经安装了Node.js和npm。如果未安装,可以通过以下链接下载并安装适合我们操作系…...
deepseek 3FS编译
3FS在ubuntu22.04下的编译(记录下编译过程,方便后续使用) 环境信息 OS ubuntu 22.04内核版本 6.8.0-52-genericlibfuse 3.16.1rust 1.75.0FoundationDB 7.1.66meson 1.0.0ninja 1.10.1 libfuse编译 以下建议均在root下执行 pip3 install…...
网安知识点
1.SQL注入漏洞产生的原因是? 前端传到后端的数据,没有经过任何处理,直接当作sql语句的一部分来执行 2.讲一下sql注入,写入webshell需要哪些前提条件 开启导入导出权限secure-file-priv 站点根目录位置/路径 mysql用户对站点根目…...
UniApp 运行的微信小程序如何进行深度优化
UniApp 运行的微信小程序如何进行深度优化 目录 引言性能优化 1. 减少包体积2. 优化页面加载速度3. 减少 setData 调用4. 使用分包加载 代码优化 1. 减少不必要的代码2. 使用条件编译3. 优化图片资源 用户体验优化 1. 优化交互体验2. 预加载数据3. 使用骨架屏 调试与监控 1. …...
leetcode-sql数据库面试题冲刺(高频SQL五十题)
题目: 577.员工奖金 表:Employee -------------------- | Column Name | Type | -------------------- | empId | int | | name | varchar | | supervisor | int | | salary | int | -------------------- empId 是该表中具有唯一值的列。 该表的每一行…...
图片分类实战:食物分类问题(含半监督)
食物分类问题 simple_class 1. 导入必要的库和模块 import random import torch import torch.nn as nn import numpy as np import os from PIL import Image #读取图片数据 from torch.utils.data import Dataset, DataLoader from tqdm import tqdm from torchvision impo…...
Java初级入门学习
JAVA学习 @[TOC](JAVA学习)**一、Java初级入门学习路径****1. Java基础语法****2. 面向对象编程(OOP)****3. 数据库与JDBC****4. Java Web基础****二、主流框架推荐与学习建议****1. Spring框架****2. Spring MVC****3. MyBatis****4. Spring Boot****三、后续学习建议****1.…...
每日一练之移除链表元素
题目: 画图解析: 方法:双指针 解答代码(注:解答代码带解析): //题目给的结构体 /*** Definition for singly-linked list.* struct ListNode {* int val;* struct ListNode *next;* }…...
BM25原理概述
1️⃣设定:对于查询 Q { q 1 , q 2 , . . . , q n } Q\text{}\{q_1,q_2,...,q_n\} Q{q1,q2,...,qn}和段落集 P { P ( 1 ) , P ( 2 ) , … , P ( N ) } \mathscr{P}\text{}\left\{P^{(1)},P^{(2)},\ldots,P^{(\text{N})}\right\} P{P(1),P(2),…,P(N)}&#…...
PAT乙级真题(2014·冬)
大纲 1031、查验身份证-(解析)-简单题 1032、挖掘机技术哪家强-(解析)-细节题(┬┬﹏┬┬),太抠细节了 1033、旧键盘打字-(解析)-输入格式!这才是重点(┬┬﹏┬┬),让…...
力大砖飞,纯暴力搜索——蓝桥p2110(写着玩的)
#include<bits/stdc.h>const int N1000000;using namespace std;bool mp[2][N];int cnt0; int n;void dfs(int row,int col){cntcnt%1000000007;if(coln && row2){cnt;return ;}if(row>2){ //下一列 dfs(0,col1);return;}if(mp[row][col]1){ //下一行 dfs(row…...
如何计算两个向量的余弦相似度
参考笔记: https://zhuanlan.zhihu.com/p/677639498 日常学习之:如何计算两个向量或者矩阵的余弦相似度-CSDN博客 1.余弦相似度定理 百度的解释:余弦相似度,又称为余弦相似性,是通过计算两个向量的夹角余弦值来评估…...
OkHttp:工作原理 拦截器链深度解析
目录 一、OKHttp 的基本使用 1. 添加依赖 2. 发起 HTTP 请求 3. 拦截器(Interceptor) 4. 高级配置 二、OKHttp 核心原理 1. 责任链模式(Interceptor Chain) 2. 连接池(ConnectionPool) 3. 请求调度…...
python: DDD+ORM using oracle 21c
sql script: create table GEOVINDU.School --創建表 ( SchoolId char(5) NOT NULL, -- SchoolName nvarchar2(500) NOT NULL, SchoolTelNo varchar(8) NULL, PRIMARY KEY (SchoolId) --#主鍵 );create table GEOVINDU.Teacher ( TeacherId char(5) NOT NULL , TeacherFirstNa…...
基于 LeNet 网络的 MNIST 数据集图像分类
1.LeNet的原始实验数据集MNIST 名称:MNIST手写数字数据集 数据类型:灰度图 (一通道) 图像大小:28*28 类别数:10类(数字0-9) 1.通过torchvision.datasets.MNIST下载并保存到本地…...
Day4 C语言与画面显示练习
文章目录 1. harib01a例程2. harib01b例程3. harib01e例程4. harib01f例程5. harib01h例程 1. harib01a例程 上一章主要是将画面搞成黑屏,如果期望做点什么图案,只需要再VRAM里写点什么就好了,使用nask汇编语言实现一个函数write_mem8&#…...
一周热点-OpenAI 推出了 GPT-4.5,这可能是其最后一个非推理模型
在人工智能领域,大型语言模型一直是研究的热点。OpenAI 的 GPT 系列模型在自然语言处理方面取得了显著成就。GPT-4.5 是 OpenAI 在这一领域的又一力作,它在多个方面进行了升级和优化。 1 新模型的出现 GPT-4.5 目前作为研究预览版发布。与 OpenAI 最近的 o1 和 o3 模型不同,…...
《UE5_C++多人TPS完整教程》学习笔记34 ——《P35 网络角色(Network Role)》
本文为B站系列教学视频 《UE5_C多人TPS完整教程》 —— 《P35 网络角色(Network Role)》 的学习笔记,该系列教学视频为计算机工程师、程序员、游戏开发者、作家(Engineer, Programmer, Game Developer, Author) Stephe…...
手写简易Tomcat核心实现:深入理解Servlet容器原理
目录 一、Tomcat概况 1. tomcat全局图 2.项目结构概览 二、实现步骤详解 2.1 基础工具包(com.qcby.util) 2.1.1 ResponseUtil:HTTP响应生成工具 2.1.2 SearchClassUtil:类扫描工具 2.1.3 WebServlet:自定义注解…...
ES Filter Query 区别
在 Elasticsearch(ES) 中,Filter 和 Query 是两种常用的数据检索方式,它们的主要区别在于 是否计算相关性分数(Score) 以及 是否使用缓存。以下是它们的详细区别和应用场景: 1. 核心区别 特性F…...
Java多线程与高并发专题——关于CopyOnWrite 容器特点
引入 在 CopyOnWriteArrayList 出现之前,我们已经有了 ArrayList 和 LinkedList 作为 List 的数组和链表的实现,而且也有了线程安全的 Vector 和Collections.synchronizedList() 可以使用。 首先我们来看看Vector是如何实现线程安全的 ,还是…...
春节面对大流量并发,系统该如何设计
基于6个层次进行系统设计以解决大流量瞬时并发问题:CDN层,Nginx层,服务层,缓存层,数据库层,全链路压测监控。以下为具体设计参考 1. CDN(内容分发网络) 作用:静态资源&…...
mac本地安装运行Redis-单机
记录一下我以前用的连接服务器的跨平台SSH客户端。 因为还要准备毕设...... 服务器又过期了,只能把redis安装下载到本地了。 目录 1.github下载Redis 2.安装homebrew 3.更新GCC 4.自行安装Redis 5.通过 Homebrew 安装 Redis 安装地址:https://git…...
77.ObservableCollection使用介绍1 C#例子 WPF例子
可观察集合ObservableCollection using System; using System.Collections.ObjectModel;class Program {static void Main(){// 创建一个可观察集合ObservableCollection<string> list new ObservableCollection<string>();// 注册集合变化事件list.CollectionCh…...
【ThreeJS Basics 09】Debug
文章目录 简介从 dat.GUI 到 lil-gui例子安装 lil-gui 并实例化不同类型的调整改变位置针对非属性的调整复选框颜色 功能/按钮调整几何形状文件夹调整 GUI宽度标题关闭文件夹隐藏按键切换 结论 简介 每一个创意项目的一个基本方面是能够轻松调整。开发人员和参与项目的其他参与…...
在 k8s中查看最大 CPU 和内存的极限
在 Kubernetes(k8s)中,你可以从不同层面查看最大 CPU 和内存的极限,下面为你详细介绍从节点和集群层面查看的方法。 查看节点的 CPU 和内存极限 节点的 CPU 和内存极限是指单个节点上可分配的最大资源量,可通过以下几…...
