Webpack 深度解析与实战指南
文章目录
- 前言
- 一、安装于基本配置
- 安装Webpack 和 Webpack CLI
- 创建基本配置文件
- 二、加载器
- 常见的加载器
- 配置加载器
- 三、插件(Plugins)
- 常用的插件
- 配置插件
- 四、性能优化
- 缓存
- 代码分割
- Tree Shaking
- 压缩
- 五、开发服务器
- 安装服务器
- 配置服务器
- 启动服务器
- 生产环境配置
- 结语
前言
Webpack 是一个现代 JavaScript 应用程序的模块打包器,它能够将各种资源(如 JavaScript、CSS、图片等)视为模块,并通过依赖图来组织这些模块,最终输出优化后的资源文件。本文将深入探讨 Webpack 的核心概念、配置方法、高级功能及最佳实践。
一、安装于基本配置
安装Webpack 和 Webpack CLI
首先,确保你的机器上已经安装了 Node.js。接着,通过 npm 安装 Webpack 和 Webpack CLI:
npm install --save-dev webpack webpack-cli
创建基本配置文件
在项目根目录下创建一个 webpack.config.js
文件,这是 Webpack 的配置入口。以下是一个简单的配置示例:
const path = require('path');module.exports = {entry: './src/index.js', // 入口文件output: {filename: 'bundle.js', // 输出文件名path: path.resolve(__dirname, 'dist') // 输出路径},module: {rules: [{test: /\.js$/, // 匹配以 .js 结尾的文件exclude: /node_modules/, // 排除 node_modules 目录下的文件use: {loader: 'babel-loader' // 使用 babel-loader 处理 ES6+ 语法}}]}
};
二、加载器
加载器是 Webpack 的核心组件之一,用于转换某些类型的模块。它们可以编译高级语言(如 TypeScript)、转换文件内容(如 LESS 到 CSS),甚至执行压缩操作。
常见的加载器
- babel-loader:编译 ES6+ 语法为向后兼容的 JavaScript。
- css-loader:解析 CSS 文件中的 @import 和 url() 语句。
- style-loader:将 CSS 注入到 DOM 中。
- file-loader 和 url-loader:处理文件引用,可以将文件输出到指定目录或将其转换为 Data URL。
- ts-loader:编译 TypeScript 代码。
配置加载器
在 webpack.config.js
中配置加载器:
module.exports = {// ...其他配置module: {rules: [{test: /\.js$/,exclude: /node_modules/,use: {loader: 'babel-loader'}},{test: /\.css$/,use: ['style-loader', 'css-loader']},{test: /\.(png|jpe?g|gif)$/i,use: [{loader: 'file-loader',options: {outputPath: 'assets/images'}}]},{test: /\.ts$/,use: 'ts-loader',exclude: /node_modules/}]}
};
三、插件(Plugins)
插件用于扩展 Webpack 的功能,支持更复杂的构建步骤
常用的插件
- HtmlWebpackPlugin:根据模板生成 HTML 文件,自动注入所有输出的脚本和样式表。
- MiniCssExtractPlugin:提取 CSS 文件,而不是将其注入到 DOM 中。
- CleanWebpackPlugin:清理输出目录。
- DefinePlugin:定义全局常量。
- HotModuleReplacementPlugin:启用模块热替换。
配置插件
在 webpack.config.js
中配置插件:
const HtmlWebpackPlugin = require('html-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const { CleanWebpackPlugin } = require('clean-webpack-plugin');module.exports = {// ...其他配置plugins: [new HtmlWebpackPlugin({template: './src/index.html'}),new MiniCssExtractPlugin({filename: '[name].[contenthash].css'}),new CleanWebpackPlugin(),new webpack.DefinePlugin({'process.env.NODE_ENV': JSON.stringify(process.env.NODE_ENV)})]
};
四、性能优化
随着项目的增长,Webpack 构建时间可能会变得非常长。为了提高性能,可以采取以下措施:
- 缓存:利用持久化缓存机制,避免重新编译未更改的模块。
- 代码分割:通过动态导入实现按需加载,减少初始加载时间。
- Tree Shaking:移除未使用的导出代码,减小打包后的文件大小。
- 压缩:使用 TerserPlugin 压缩 JavaScript 文件,使用 mini-css-extract-plugin 提取并压缩 CSS 文件。
缓存
Webpack 默认会缓存中间文件,但你可以通过配置进一步优化缓存:
module.exports = {// ...其他配置cache: {type: 'filesystem'}
};
代码分割
使用动态导入(import()
)进行代码分割:
button.addEventListener('click', () => {import('./module.js').then((module) => {module.default();});
});
Tree Shaking
确保使用严格模式编写代码,并启用 sideEffects
标记:
{"sideEffects": false
}
压缩
配置 TerserPlugin
和 MiniCssExtractPlugin
进行压缩:
const TerserPlugin = require('terser-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');module.exports = {// ...其他配置optimization: {minimizer: [new TerserPlugin(),new MiniCssExtractPlugin({filename: '[name].[contenthash].css'})]}
};
五、开发服务器
Webpack 还提供了一个强大的开发服务器 webpack-dev-server,它支持热模块替换(HMR),允许你在修改代码后立即看到效果,而无需刷新整个页面。
安装服务器
npm install --save-dev webpack-dev-server
配置服务器
在 webpack.config.js
中配置开发服务器:
module.exports = {// ...其他配置devServer: {contentBase: './dist',hot: true,port: 3000},plugins: [new webpack.HotModuleReplacementPlugin()]
};
启动服务器
在 package.json
中添加启动命令:
"scripts": {"start": "webpack serve --open"
}
现在,只需运行 npm start 即可启动开发服务器,并自动打开浏览器窗口访问应用。
生产环境配置
对于生产环境,推荐使用 mode 参数来指定环境类型,这将启用不同的优化策略:
module.exports = {mode: 'production',// ...其他配置
};
多页应用(Multi-page Application)
对于多页应用,可以配置多个入口点:
module.exports = {entry: {pageOne: './src/pageOne/index.js',pageTwo: './src/pageTwo/index.js'},output: {filename: '[name].bundle.js',path: path.resolve(__dirname, 'dist')},// ...其他配置
};
源码映射(Source Maps)
源码映射可以帮助你在浏览器开发者工具中调试原始源代码,而不是编译后的代码。可以在 webpack.config.js
中配置源码映射:
module.exports = {// ...其他配置devtool: 'source-map'
};
结语
Webpack 是一个强大且灵活的工具,适用于各种规模的应用程序开发。通过合理配置加载器和插件,以及实施有效的性能优化策略,可以显著提升开发效率和用户体验。希望本文能够帮助你更好地理解和使用 Webpack!
相关文章:
Webpack 深度解析与实战指南
文章目录 前言一、安装于基本配置安装Webpack 和 Webpack CLI创建基本配置文件 二、加载器常见的加载器配置加载器 三、插件(Plugins)常用的插件配置插件 四、性能优化缓存代码分割Tree Shaking压缩 五、开发服务器安装服务器配置服务器启动服务器生产环…...
【RabbitMQ】06-消费者的可靠性
1. 消费者确认机制 没有ack,mq就会一直保留消息。 spring:rabbitmq:listener:simple:acknowledge-mode: auto # 自动ack2. 失败重试机制 当消费者出现异常后,消息会不断requeue(重入队)到队列,再重新发送给消费者。…...
【K8S系列】如何监控集群CPU使用率并设置告警的分析与详细解决方案
监控 Kubernetes 集群的 CPU 使用率并设置告警是确保集群健康和性能的关键。以下是几种常见的方案,每种方案的具体步骤都进行了详细说明。 方案 1: 使用 Prometheus 和 Grafana 1. 安装 Prometheus 和 Grafana 1.1 使用 Helm 安装 Prometheus 添加 Helm 仓库: hel…...
解线性方程组(二)
实验类型:●验证性实验 ○综合性实验 ○设计性实验 实验目的:进一步熟练掌握用Jacobi迭代法和Gauss-Seidel法解线性方程组的算法,提高编程能力和解算线性方程组问题的实践技能。 实验内容: 1)取初值性x(0)(0,0,0,0)T, 精度要求ε…...
HarmonyOS Next 实战卡片开发 02
HarmonyOS Next 实战卡片开发 02 卡片开发中,还有一个难点是显示图片。其中分为显示本地图片和显示网络图片 显示本地图片 卡片可以显示本地图片,如存放在应用临时目录下的图片。路径比如 /data/app/el2/100/base/你的项目boundleName/temp/123.png 以…...
FastDDS服务发现之PDP的收发
目录 PDP发送PDP接收EDP更新 EntityID 通过FastDDS服务发现之PDP和EDP的创建这一节内容,可以了解服务发现的概念,机制和PDP/EDP中各类对象的创建,本文详细介绍Simple PDP发送数据,接收数据和处理报文的流程。 PDP发送 通过在RTP…...
【计网不挂科】计算机网络期末考试——【选择题&填空题&判断题&简述题】试卷(2)
前言 大家好吖,欢迎来到 YY 滴计算机网络 系列 ,热烈欢迎! 本章主要内容面向接触过C的老铁 本博客主要内容,收纳了一部门基本的计算机网络题目,供yy应对期中考试复习。大家可以参考 本章是去答案版本。带答案的版本在下…...
关于有机聚合物铝电容的使用(2)
在使用时需要特别注意的几个应用场景: 在有较长供电电缆或PCB电源布线较长的场合。 这个场景应当仍与有机聚合物铝电容的耐压有关。 假设在相同的冲击电流下,较长的供电电缆和PCB布线,那么电缆和PCB布线上产生的冲击电压就会越高。故而&…...
Linux -- 进程初印象
目录 预备知识 切入点 PCB 看见进程 pid getpid 函数 预备知识 Linux -- 冯诺依曼体系结构(硬件)-CSDN博客https://blog.csdn.net/2301_76973016/article/details/143598784?spm1001.2014.3001.5501 Linux -- 操作系统(软件…...
【超级简单】Facebook脸书视频下载一键保存手机
Facebook作为目前服务全球30亿用户,尤其是出海和跨境用户没有办法忽视的平台,提供了一个在线平台,使用户分享照片、视频、状态更新和链接等内容,然而,令人遗憾的是,用户没有办法直接将照片和视频保存到本地…...
昇思大模型平台打卡体验活动:项目2基于MindSpore通过GPT实现情感分类
昇思大模型平台打卡体验活动:项目2基于MindSpore通过GPT实现情感分类 1. 载入与处理数据集 在情感分类任务中,我们使用了IMDB数据集,首先需要对数据进行加载和处理。由于原数据集没有验证集,我们将训练集重新划分为训练集和验证…...
【JAVA】会员等级互通匹配数据库表设计
1、使用数据库:mysql数据库 设计四张表: 会员互通合作商配置表 会员互通合作商会员等级配置表 会员互通合作日志表 会员互通合作等级映射表 CREATE TABLE user_level_partner ( id bigint NOT NULL AUTO_INCREMENT, partner_novarchar(100) DE…...
论文阅读:基于语义分割的非结构化田间道路场景识别
论文地址:DOI: 10.11975/j.issn.1002-6819.2021.22.017 概要 环境信息感知是智能农业装备系统自主导航作业的关键技术之一。农业田间道路复杂多变,快速准确地识别可通行区域,辨析障碍物类别,可为农业装备系统高效安全地进行路径规…...
linux部分问题以及解决方式
目录 1.ubuntu桌面不显示了,只有命令行1.1启动gdm3服务1.2安装lightdm桌面管理包 1.ubuntu桌面不显示了,只有命令行 有如下两种解决方式。 1.1启动gdm3服务 这种方法只能临时生效,每次重启都要手动启动 sudo service gdm3 restart 1.2安装…...
qt QTreeWidget详解
1、概述 QTreeWidget 是 Qt 框架中的一个类,用于以树形结构展示数据。它基于 QTreeView 并提供了更高级别的接口,使得添加、删除和管理树形结构中的项变得更加简单。QTreeWidget 支持多级嵌套,每个项(QTreeWidgetItem)…...
注意力机制的目的:理解语义;编码器嵌入高纬空间计算;注意力得分“得到S*V”;解码器掩码和交叉注意力层用于训练;最终的编码器和输出实现大模型
目录 注意力机制的目的:理解语义中的它是小白兔 词编码器嵌入高纬空间 计算注意力得分“得到S*V” 权重QKV:连接权重 训练阶段使用解码器:翻译后的语句 解码器掩码和交叉注意力层用于训练 最终的编码器和输出实现大模型 Transformer模型中,QKV QKV的作用 举例说明…...
[java][jdk]JDK各个版本的核心特性
JDK 8至JDK 21的主要新特性概览: JDK 8 Lambda表达式:引入了函数式编程的特性,使得代码更加简洁和灵活。Stream API:提供了一种新的抽象,可以让你以声明性方式处理集合数据。新的日期和时间API:引入了jav…...
双十一”买买买!法官告诉你注意这些法律问题
“双十一”等购物节来临之际,某些电商平台为了吸引消费者提前下单预订商品,通过大力宣传付定金可享受更多优惠等方式开启预售模式。那么,如果消费者在支付定金后,因各种原因最终没有支付尾款,能否要求商家退还定金&…...
PyQt5
基于PyQt5的重绘机制实现加载页面 效果预览代码说明控件初始化超时回调重绘事件缩放事件 代码获取 效果预览 直接看图,效果展现为跟随黑点顺时针转动,且有明暗变化 代码说明 控件初始化 initUI主要用于初始化用户界面(UI)。它创建了一个具有特定样式…...
【Linux】常用命令(2.6万字汇总)
文章目录 Linux常用命令汇总1. 基础知识1.1. Linux系统命令行的含义1.2. 命令的组成 2. 基础知识2.1. 关闭系统2.2. 关闭重启2.3. 帮助命令(help)2.4. 命令说明书(man)2.5. 切换用户(su)2.6.历史指令 3.目录…...
Vue3-06_路由
路由 后台路由是根据请求url,匹配请求处理的后台模块(路径) 前台根据访问路径,决定显示的内容。 路由就是: 访问hash 与内容的对应关系 路由的工作方式 用户点击页面的路由链接导致url地址栏中的Hash值发生了变化前…...
物理验证Calibre LVS | SMIC Process过LVS时VNW和VPW要如何做处理?
SMIC家工艺的数字后端实现PR chipfinish写出来的带PG netlist如下图所示。我们可以看到标准单元没有VNW和VPW pin的逻辑连接关系。 前几天小编在社区星球上分享了T12nm ananke_core CPU低功耗设计项目的Calibre LVS案例,就是关于标准单元VPP和VBB的连接问题。 目前…...
量化分析工具日常操作日记-5-通合科技
使用量化分析微信小程序工具“梦想兔企业智能风险分析助手”日常操作日记-5-军工-通合科技(300491)。 周末国家新政策,要大力支持军工行业,我用工具挖掘了两个低位股,供大家参考。通合科技(300491ÿ…...
windows和linux验证MD5码方式
一、linux linux自带MD5码验证: $ md5sum target_file.txt 二、windows windows自带的MD5码验证: $ certutil -hashfile target_file.txt MD5...
构造函数原型对象语法、原型链、原型对象
目录 一、前言 二、编程思想 面向过程 面向对象 三、构造函数 四、原型对象 constructor 属性 对象原型 原型继承 原型链 一、前言 通过本篇博客,我们将了解面向对象编程的一般特征,掌握基于构造函数原型对象的逻辑封装,掌握基于原…...
鸿蒙UI开发——自定义UI绘制帧率
1、概 述 随着设备屏幕的不断演进,当前主流设备采用LTPO屏幕(可变刷新率屏幕),此类屏幕支持在多个档位之间切换屏幕帧率。 对于快速变化的内容,如射击游戏,交互动画等,显示帧率越高࿰…...
鸿蒙基本组件结构
组件结构 1. 认识基本的组件结构 ArkTS通过装饰器Component 和Entry 装饰 struct 关键字声明的数据结构,构成一个自定义组件 自定义组件中提供了一个build函数,开发者需要在函数内以链式调用的方式进行基本的UI描述,UI描述的方法请参考UI描述…...
柔性鞋材振动刀智能视觉裁切机市场报告:未来几年年复合增长率CAGR为5.4%
震动刀切割设备是一种利用振动刀片在各种非金属材料表面上切割的设备,振动刀切割机利用刀片高频振动和360度旋转,能保证每分钟上万次的振动频率,可在平面进行垂直切割,锋利裁剪。震动刀切割设备切割速度快,可以单层切割…...
【计算机网络】基础知识,常识应用知识
局域网使用的是广播技术,广域网使用的是点对点技术,使用的协议不同。局域网工作在数据链路层,可以不要网络层,不存在路由选择问题。1968年6月,世界上最早的计算机网络是ARPAnet服务原语:请求、指示、相应、…...
【Linux进程篇1】认识冯·诺依曼体系结构(引出进程详解)
--------------------------------------------------------------------------------------------------------------------------------- 每日鸡汤: 用这生命中的每一秒,给自己一个不后悔的未来。 -----------------------------------------------…...
江门站官网/短视频排名seo
生活中虽然有难过的事情,但是要微笑面对哦!下面是由出国留学网编辑为大家整理的“关于难过的作文400字”,仅供参考,欢迎大家阅读。关于难过的作文400字(一)星期六下午,我到妈妈的“第一时间”快餐店的办公室玩…...
有域名怎么建设网站/朝阳seo排名优化培训
我的独立域名博客~~ http://codingnow.cn...
WordPress全屏图/深圳有实力的seo公司
Vue每日签到日历渲染Vue每日签到日历渲染先上图templatescriptstyleVue每日签到日历渲染 先上图 template <template><div class"sign"><div class"header-title"><div>每日签到</div></div><div style"wid…...
长春网站制作允许吗/百度推广的四种收费形式
工厂方法模式(Factory Method Pattern)是“创建对象的接口,让子类决定实例化哪一个类,并使一个类的实例化延迟到其子类”。工厂方法模式在平常的开发工作中经常会用到。以人类为例,先来看看一般的工厂方法模式是如何实…...
如何建立一家公司网站/今天nba新闻最新消息
2019独角兽企业重金招聘Python工程师标准>>> 要对一张模版图片进行处理,替换其中的部分,包括文字和图片。 1、主要使用 imagecreatefromjpeg 从JPG文件创建图像对象、 imagecreatefrompng从PNG文件创建图像对象、 getimagesize获取图像对象的…...
可以做砍价链接的网站/2019网站seo
2019独角兽企业重金招聘Python工程师标准>>> 当选择左边的一级选项时,左边展示一级选项里含有的二级选项,选择后显示在TextField里。 如何实现呢?建立一个和左边的列表key对应的数组,当选择这个key时,刷新左…...