前端性能优化-webpack构建优化
前言
本文主要总结 webpack 构建优化相关的事情
PS: webpack 的每次更新都会带来很多的新特性,因此学习新知识的时候,不要专注于流程的配置和调参。因为流程终会简化,参数(API)终会升级。要抓大放小,把精力放在最核心的内容上,因为核心的思想是最不容易过时的.
webpack 性能瓶颈
webpack 优化主要分为两个方向:
构建速度优化
- 使用最新版本的 webpack,一般融合了最佳实践
- 文件过滤:使用 include 和 exclude, ignorePlugin 等
- 优化 resolve.modules 配置: 合理配置 resolve.modules,指定 Webpack 去哪些目录下寻找模块。避免过多的目录会加速模块的查找速度。
- 优化 loader(减少 loader 链的复杂性, 如 thread-loader 或 cache-loader)
- 利用多核 CPU 多进程构建( HappyPack 或者 Webpack 5 提供的 cache 和 parallel 选项)
- 缓存(DLL 等空间换时间的方案)
- 使用更轻量的 SourceMap(cheap-module-source-map)
- 代码分割: 将代码拆分成小块,只加载在当前页面上需要的部分。
- 合理配置打包版本
代码分割(拆包 splitChunks)
在不配置拆包的情况下,Webpack 会将所有的资源都打包在一个 js 文件中,这无疑会让请求时候的响应体积变得非常大,从而降低加载速度。
同时,不配置拆包,会在首次加载的时候加载一些无关的资源,浪费了一次宝贵的请求。合理配置拆包,让每次请求都只请求对应的核心资源,从而达到按需加载的程度。
拆包通常的逻辑:
- 业务代码和第三方依赖进行拆分
- 对于第三方依赖:
- 将版本经常变动的与版本不怎么变动的进行拆分
- 版本不怎么变动的依赖可以合理配置 CDN
- 对于业务代码:
- 将业务模块和公共模块进行拆分
- 业务模块也根据调用的次数进行拆分
- 将首屏模块单独进行拆分
合理配置打包版本
代码体积优化
- Three shaking 移除项目中未使用的代码
- 压缩代码: 如 terser-webpack-plugin, css-minimizer-webpack-plugin
- 分割代码(Code Splitting)
- 动态导入(Dynamic Import)
- import(‘some-module’).then(({ someModule }) => {// 使用 someModule});
- 提取公共模块: 通过 Webpack 的 CommonsChunkPlugin 或 optimization.splitChunks 来提取公共模块,减小重复模块的体积
- 图像、字体等资源优化
掌握优化策略,然后用到的时候直接通过官方文档查找最新的 API 即可或者搜索关键字即可
参考
- https://jelly.jd.com/article/61179aa26bea510187770aa3
- https://juejin.cn/post/6844903952140468232
本文首发于个人博客前端开发笔记,由于笔者能力有限,文章难免有疏漏之处,欢迎指正
相关文章:
前端性能优化-webpack构建优化
前言 本文主要总结 webpack 构建优化相关的事情 PS: webpack 的每次更新都会带来很多的新特性,因此学习新知识的时候,不要专注于流程的配置和调参。因为流程终会简化,参数(API)终会升级。要抓大放小,把精力…...
Traefik:部署与实战
一、介绍Traefik Traefik是一个开源的反向代理和负载均衡器,专为现代化的微服务架构设计。它可以与各种容器化平台(如Docker、Kubernetes)和服务发现工具(如Consul、Etcd)集成,使部署和管理服务变得更加简…...
[Spring] SpringBoot统一功能处理与图书管理系统
🌸个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 🏵️热门专栏: 🧊 Java基本语法(97平均质量分)https://blog.csdn.net/2301_80050796/category_12615970.html?spm1001.2014.3001.5482 🍕 Collection与…...
实现吸顶效果,一个页面多个元素吸顶效果
前言 新业务开发用到了吸顶效果而且是一个页面滚动到不同的位置不同的元素进行吸顶叠加。我是基于uniapp去写的,原理思路都一样 代码部分 下面的代码我写了两种方法都是一样的一个是通过js控制变量添加元素一个是直接通过css样式进行控制 <!-- 上半部总览位置…...
【C++入门(下)】—— 我与C++的不解之缘(二)
前言 接上篇,继续来学习C,本篇内容大概有 引用,inline 和 nullptr。 六、引用: 6.1、引用的定义 引用不是新定义一个变量,而是给已存在的变量取了一个别名,编译器不会为引用变量开辟内存空间,它…...
【数据结构】哈希应用-STL-位图
目录 1、位图的概念 2、位图的设计与实现 2.1 set 2.2 reset 2.3 test 3、C库中的位图 4、位图的优缺点 5、位图相关题目 1、位图的概念 面试题:给40亿个不重复的无符号整数,没排过序。给一个无符号整数,如何快速判断一个数是否在这4…...
Unbuntu 服务器- Anaconda安装激活 + GPU配置
一、Anaconda安装激活 1.更新 sudo apt-get update 2.安装wget、vim sudo apt-get install wget sudo apt-get install vim 3.安装Anaconda 进入这个网址:Index of /anaconda/archive/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror 点这里&#x…...
python 装饰器记录函数用时
装饰器 # 用于记录函数平均用时的装饰器 def average_time_decorator(func):times []def wrapper(*args, **kwargs):start_time time.time()result func(*args, **kwargs)end_time time.time()t end_time - start_timetimes.append(t) # 记录用时print(f"{func.__n…...
实验10 任何一个非0自然数m的立方均可写成m个连续奇数之和。
实验10 题目描述 任何一个非0自然数m的立方均可写成m个连续奇数之和。 例如: 1^3 1 2^3 35 3^3 7911 4^3 13151719 编程实现:输入一自然数n,求组成心的n个连续奇数。 【实验要求】 1、不允许用等差数列的方法求首项 2、要求使用双重循环&a…...
Jenkins的安装方式
一、Jenkins是什么 Jenkins是一款开源CI&CD软件,用于自动化构建、测试和部署软件等各种任务,以实现持续集成。 Jenkins支持各种运行方式,可通过系统包、Docker或者通过一个独立的Java程序。 二、安装方式 2.1禅道智能应用平台一键安装…...
网络之华为S5700S-52P-LI交换机系统恢复
一、需求说明 盒式交换机flash存储空间一般比较小,只有几百兆,部分比较可能不到100M。当然一般情况下也是够用的,只有在日志文件等占用较多,或者ios系统升级较多,bin文件占用较多的情况下可能出现不够用的情况。什么情…...
蜂窝网络架构
2G/3G 4G eNB RF-RRU eCPRI RRU-BBU 光纤 5G From 38.300 AMF处理信令等,UPF 用户面,后面还有SMF...
培训第二十二天(mysql数据库主从搭建)
上午 1、为mysql添加开机启动chkconfig [rootmysql1 ~]# chkconfig --list //列出系统服务在不同运行级别下的启动状态注:该输出结果只显示 SysV 服务,并不包含原生 systemd 服务。SysV 配置数据可能被原生 systemd 配置覆盖。 要列出 systemd 服务…...
速盾:CDN回源失败都有什么原因?
CDN(内容分发网络)是一种通过将内容分发到全球各个边缘节点来提高网站访问速度和用户体验的网络技术。CDN回源失败是指CDN节点无法正常获取源站(原始服务器)上的内容。下面是一些可能导致CDN回源失败的常见原因: 网络故…...
C语言 | Leetcode C语言题解之第328题奇偶链表
题目: 题解: struct ListNode* oddEvenList(struct ListNode* head) {if (head NULL) {return head;}struct ListNode* evenHead head->next;struct ListNode* odd head;struct ListNode* even evenHead;while (even ! NULL && even->…...
8月6日笔记
8月6日 红日靶场打靶继续 SHOW VARIABLES #用于显示服务器运行时的各种系统变量的当前设置。这些变量可以控制服务器的行为在 MySQL 中,general_log 和 general_log_file 是两个与“general”相关的系统变量,它们控制着服务器是否启用一般查询日志以及…...
爱可声助听器:在全球听力市场中破冰前行
早在2021年,全球助听器市场规模就已经达到了101亿美元,Grand View Research数据显示,这一规模会持续增大,在未来的6年间,该数据将以4.9%的复合年增长率(CAGR)增长。 作为发展中国家,…...
华为OD面试 - 最佳升级时间窗(Java JS Python C C++)
题目描述 有一套系统需升级,为减小系统升级期间的影响,需根据系统过去一段时间内的每小时平均访问数据,来预测最佳升级时间窗。 现给长度为168(7 * 24)的整数数组,表示一个周期(假设从周一00:00到周日24:00)的每小时历史数据,最佳升级时间窗选择规则如下: 时间窗内…...
LE-50821F/FA激光扫描传感器|360°避障雷达之性能参数与配置清单说明
LE系列激光扫描传感器|360避障雷达涵盖LE-50711、LE-50711F、 LE-50621、LE-50821F、LE-50621F、LE-50821FA、LE-50711FA、LE-50621FA等型号,广泛应用于自动化工厂、物流与仓储、汽车制造与物流、机械设备、能源与环境等领域的环境感知、高精度定位(…...
精准洞察农田生态,智慧农业物联网环境监测与数据采集系统来袭
随着智慧农业的快速发展,利用物联网技术实现对农田种植状态的精准监测变得愈发重要。为了确保监测的准确性、一致性和有效性,规范农田物联网监测设备的技术参数、部署安装以及数据对接等技术指标势在必行。 本文技术说明旨在为相关设备的选择、安装和集…...
dplyr和tidyr用法释
1. 引入 在现代 AI 工程中,Hugging Face 的 tokenizers 库已成为分词器的事实标准。不过 Hugging Face 的 tokenizers 是用 Rust 来实现的,官方只提供了 python 和 node 的绑定实现。要实现与 Hugging Face tokenizers 相同的行为,最好的办法…...
Qwen3.5-9B GPU高性能部署:TensorRT-LLM引擎集成实测指南
Qwen3.5-9B GPU高性能部署:TensorRT-LLM引擎集成实测指南 1. 项目概述 Qwen3.5-9B是一款拥有90亿参数的开源大语言模型,在逻辑推理、代码生成和多轮对话方面表现出色。最新版本还支持多模态理解(图文输入)和长达128K tokens的上…...
Ostrakon-VL在Qt桌面应用中的集成:开发跨平台视觉工具
Ostrakon-VL在Qt桌面应用中的集成:开发跨平台视觉工具 1. 为什么选择QtOstrakon-VL组合 在开发跨平台视觉分析工具时,Qt框架和Ostrakon-VL模型的组合提供了独特优势。Qt作为成熟的跨平台GUI框架,可以轻松构建Windows、Linux和macOS上的原生…...
HarmonyOS 6学习:Swiper组件圆点指示器颜色叠加问题解析与解决方案
一、前言:一个看似简单却困扰开发者的视觉问题在HarmonyOS应用开发中,Swiper组件作为实现轮播图、图片浏览、引导页等功能的利器,被广泛应用于各类应用场景。其内置的圆点指示器(indicator)功能,为用户提供…...
建议大家都去油管学ai agent真的能打破信息差
① Jeff su 视频节奏快、内容直给,特别适合普通人想用AI做点实际事儿的,比较入门和实用;比如他用8分钟说清楚怎么写好prompt、怎么用AI agent,讲得清楚又好跟,新手照做就能上手。 ② Andrej Karpathy 大神本神&…...
别再手动改时间了!Ubuntu 22.04 用 timedatectl 一键切换时区到 Asia/Shanghai 的完整指南
告别时间混乱:Ubuntu 22.04 时区管理终极指南 刚装好Ubuntu系统,发现右下角的时间总是不对?每次连接远程服务器都要手动计算时差?作为Linux新手,你可能还在图形界面里翻找时区设置,或者用着老旧的tzselect…...
SDMatte Web界面交互优化点:框选反馈延迟降低、结果预览缩放、批量上传支持
SDMatte Web界面交互优化点:框选反馈延迟降低、结果预览缩放、批量上传支持 1. 产品概述 SDMatte 是一款面向高质量图像抠图场景的 AI 模型,特别适合处理以下专业需求: 主体分离:从复杂背景中精确提取目标物体透明物体提取&…...
从零开始:Qwen2.5-3B大模型LoRA微调与ollama本地部署实战
1. 环境准备与工具安装 想要玩转Qwen2.5-3B大模型的微调和部署,首先得把工具和环境准备好。我建议使用Linux系统(Ubuntu 20.04)或者MacOS,Windows用户可以考虑WSL2。以下是需要安装的核心工具: Python 3.9࿱…...
FireRedASR-AED-L实现Python语音识别:从音频到文本的完整教程
FireRedASR-AED-L实现Python语音识别:从音频到文本的完整教程 1. 引言 语音识别技术正在改变我们与设备交互的方式,从智能助手到实时字幕,这项技术已经深入到日常生活的方方面面。今天我要介绍的FireRedASR-AED-L,是一个专门为中…...
Star CCM+ 实战:旋风分离器(cyclone separator)体网格生成与优化策略
1. 旋风分离器网格生成前的准备工作 在开始使用Star CCM生成旋风分离器体网格之前,我们需要做好充分的准备工作。旋风分离器作为一种常见的气固分离设备,其内部流动特性复杂,包含强烈的旋转流场和湍流现象。这就对网格质量提出了更高要求&am…...
