• 前端构建工具 webpack 笔记


    • 1、了解 webpack 

    1、定义:本质上,webpack 是一个用于现代 JavaScript 应用程序的静态模块打包工具,当 webpack 处理应用它会在内部从一个或多个入口点构建一个依赖图(dependency graph),然后将你项目中所程序时,需的每一个模块组合成一个或多个 bundles,它们均为静态资源,用于展示你的内容。

    2、静态模块:指的是编写代码过程中的,html,css,js,图片等固定内容的文件

    3、打包:把静态模块内容,压缩,整合,转译等(前端工程化)

            1)把 less / sass 转成 css 代码

            2)把 ES6+ 降级成 ES5

            3)支持多种模块标准语法

    4、问题:为何不学 vite ?

            因为:很多项目还是基于 Webpack 构建,并为 Vue React 脚手架使用做铺垫!


    • 2、使用 webpack

    1、需求:封装 utils 包,校验手机号长度和验证码长度,在 src/index.js 中使用并打包观察

    2、步骤:

            1)新建并初始化项目,编写业务源代码

    1. 1、创建包管理文件:package.json
    2. npm init -y
    3. 2、编写业务代码

            2)下载 webpack webpack-cli 到当前项目中(版本独立),并配置局部自定义命令

    1. Webpack是一个功能强大的模块打包工具,而Webpack-CLI则是用于在命令行中执行Webpack相关操作的工具。
    2. 它们通常一起使用,以便更好地管理和构建前端项目。
    3. 1、终端:
    4. npm i webpack webpack-cli --save-dev
    5. 2、package.json: [我们自定义一个命令 build,但是最终执行的是 webpack]
    6. "scripts": {
    7. "build":"webpack"
    8. }

            3)运行打包命令,自动产生 dist 分发文件夹(压缩和优化后,用于最终运行的代码)

    1. 执行我们定义的命令,即执行了 webpack ,进行打包
    2. npm run build


    • 3、修改 Webpack 打包出入口

    webpack 官方文档:概念 | webpack 中文文档 (docschina.org) 

    1)项目根目录,新建 webpack.config.js 配置文件

    2)导出配置对象,配置入口,出口文件的路径

    1、下面是引入 path 模块 ,path.resolve作用是,把下面 __dirname (可得到当前绝对路径) 和后面的字符串,拼接成一个绝对路径

    2、entry:配置需要打包文件的文件路径

    3、output:配置打包后文件的存储显示路径

            1)这里的path.resolve第二参数是打包后输出的文件夹名称

            2)filename:配置打包后的文件名

            3)clean: true  生成打包后内容之前,清空原有的输出目录【和filename同位置】

    3)重新打包观察 注意:只有和入口产生直接/间接的引入关系,才会被打包

    执行命令,npm run build,最后输出如下图框中

    4)打包后的 js 文件,例子如下【我用了自动换行,让你们看清楚】


    • 4、webpack 打包输出 index.html 文件

    注意:前面我们打包的都是 js 文件,那么 html 文件怎么打包到 dist 文件夹里面呢?

    官方网址指向HtmlWebpackPlugin | webpack 中文文档 (docschina.org)

    1)安装对应的包

        npm install html-webpack-plugin --save-dev
    

    2)在 webpack.config.js 中配置

    3)重新打包观察

    执行命令,npm run build,最后输出如下图框中

     4)打包后的 html 文件,例子如下【我用了自动换行,让你们看清楚】


    • 5、webpack 打包 css 代码 【js 文件中】

    1、和 打包 html 文件一样,我们需要下载对应的包,用于 打包 该文件 到 【js 文件中】

            1)加载器 css-loader:解析 css 代码

            2)加载器 style-loader:把解析后的 css 代码插入到 DOM

    2、注意:Webpack 默认只识别 js 代码

    3、官方网址指向:

    css-loader | webpack 中文文档 (docschina.org)

    style-loader | webpack 中文文档 (docschina.org)

    1)准备 css 文件代码引入到 src 文件夹中

    2)准备 css 代码,并引入到 js 中 【没错,就是引入 js 文件中】

    2)下载 css-loader 和 style-loader 本地软件包

    1. 同时,下载两个加载器
    2. npm i css-loader style-loader --save-dev

    3)配置 webpack.config.js 让 Webpack 拥有该加载器功能

    1. module.exports = {
    2. module: {
    3. rules: [
    4. {
    5. // 匹配 css 文件,/i 就是 无论后缀大小写
    6. test: /\.css$/i,
    7. // 使用 这两个加载器,注意,它是从最后一个元素【这里是css-loader】开始使用,顺序不能改变
    8. use: ["style-loader", "css-loader"],
    9. },
    10. ],
    11. },
    12. };

    4)重新打包观察

    执行命令,npm run build,最后输出如下图框中【注意,下面是 js 文件】

    最后 打包后页面 和 打包前页面 展示 一样


    • 6、webpack 打包 css 代码【css 文件中】

     1、下载对应的包,用于 打包 该文件 到【独立的 css 文件中】

            1)加载器 css-loader:解析 css 代码

            2)插件 mini-css-extract-plugin:提取 css 代码 【webpack5 才有】

    2、注意:【mini-css-extract-plugin 不能和 style-loader 一起使用】

    3、好处:css 文件可以被浏览器缓存,减少 js 文件体积

    4、官方网址指向:

    css-loader | webpack 中文文档 (docschina.org)

    MiniCssExtractPlugin | webpack 中文文档 (docschina.org)

    1、下载 mini-css-extract-plugin 本地软件包

        npm install mini-css-extract-plugin --save-dev

    2、配置 webpack.config.js 让 Webpack 拥有该插件功能

    1. const MiniCssExtractPlugin = require("mini-css-extract-plugin");
    2. module.exports = {
    3. plugins: [new MiniCssExtractPlugin()],
    4. module: {
    5. rules: [
    6. {
    7. test: /\.css$/i,
    8. // 注意:style-loader 和 MiniCssExtractPlugin.loader 不能同时使用
    9. // use: ['style-loader', "css-loader"],
    10. use: [MiniCssExtractPlugin.loader, "css-loader"],
    11. },
    12. ],
    13. },
    14. };

    3、打包后观察效果

    注意:执行命令,npm run build,这里 打包后 的 css 代码,还没有被压缩


    • 7、webpack 打包 css 代码【压缩 css 代码】

     1、下载对应的包,用于 打包 该文件 到【独立的 css 文件中】

            1)加载器 css-loader:解析 css 代码

            2)mini-css-extract-plugin:提取 css 代码 【webpack5 才有】

            3)css-minimizer-webpack-plugin :压缩 css 代码

    2、注意:【mini-css-extract-plugin 不能和 style-loader 一起使用】

    3、好处:css 文件可以被浏览器缓存,减少 js 文件体积

    4、官方网址指向:

    css-loader | webpack 中文文档 (docschina.org)

    MiniCssExtractPlugin | webpack 中文文档 (docschina.org)​​​​​​

    MiniCssExtractPlugin | webpack 中文文档 (docschina.org)  【这个是生产模式压缩】

    1、下载 css-minimizer-webpack-plugin 本地软件包

        npm install css-minimizer-webpack-plugin --save-dev

    2、配置 webpack.config.js 让 Webpack 拥有该插件功能

    1. const MiniCssExtractPlugin = require("mini-css-extract-plugin");
    2. const CssMinimizerPlugin = require("css-minimizer-webpack-plugin");
    3. module.exports = {
    4. plugins: [new MiniCssExtractPlugin()],
    5. module: {
    6. rules: [
    7. {
    8. test: /.s?css$/,
    9. use: [MiniCssExtractPlugin.loader, "css-loader"],
    10. },
    11. ],
    12. },
    13. optimization: {
    14. minimizer: [
    15. // 在 webpack@5 中,你可以使用 `...` 语法来扩展现有的 minimizer(即 `terser-webpack-plugin`)
    16. `...`, // 保留这个,就是使 js 代码打包后,还能压缩
    17. new CssMinimizerPlugin(),
    18. ],
    19. }
    20. };;

    3、打包后观察效果

     注意:执行命令,npm run build,这里的 css 代码已经被压缩了


    • 8、webpack 打包 less 代码

     1、下载对应的包,用于 打包 该文件

            1)加载器 css-loader:解析 css 代码

            2)mini-css-extract-plugin:提取 css 代码 

            3)less less-loader:下载 less 和 less-loader 包

    2、注意:【mini-css-extract-plugin 不能和 style-loader 一起使用】

    3、官方网址指向:

    css-loader | webpack 中文文档 (docschina.org)

    MiniCssExtractPlugin | webpack 中文文档 (docschina.org)​​​​​​

    less-loader | webpack 中文文档 (docschina.org)

    1、下载 less less-loader 本地软件包

         npm install less less-loader --save-dev

    2、新建 less 代码(设置背景图)并引入到 index.js 中 

    3、配置 webpack.config.js 让 Webpack 拥有该插件功能

    1. const MiniCssExtractPlugin = require("mini-css-extract-plugin");
    2. module.exports = {
    3. plugins: [new MiniCssExtractPlugin()],
    4. module: {
    5. rules: [
    6. {
    7. test: /\.less$/i,
    8. use: [
    9. MiniCssExtractPlugin.loade,
    10. 'css-loader',
    11. 'less-loader',
    12. ],
    13. },
    14. ],
    15. },
    16. };

    4、打包后观察效果

     注意:执行命令,npm run build,因为用了mini-css-extract-plugin,最后,这段代码打包后,在输出的 css 文件中【注意:图片所在的文件夹也被打包到 dist 文件夹里面了】


    • 9、webpack 打包图片

    资源模块:Webpack5 内置资源模块(字体,图片等)打包,无需额外 loader,无需下载包

    官方网址指向:资源模块 | webpack 中文文档 (docschina.org)

    1、配置 webpack.config.js 让 Webpack 拥有打包图片功能

    • 这个规则的作用是匹配以 .png.jpg.jpeg.gif 结尾的文件,并使用 asset 模块类型进行处理。
    • asset 模块类型是 webpack 5 引入的一种处理资源的方式,它会根据文件大小,自动决定是将文件转换为 Data URL (DataURL),还是将其复制到输出目录。 

    1)占位符 【hash】对模块内容做算法计算,得到映射的数字字母组合的字符串

    2)占位符 【ext】使用当前模块原本的占位符,例如:.png / .jpg 等字符串

    3)占位符 【query】保留引入文件时代码中查询参数(只有 URL 下生效)

    1. module.exports = {
    2. plugins: [new MiniCssExtractPlugin()],
    3. module: {
    4. rules: [
    5. ...
    6. {
    7. test: /\.(png|jpg|jpeg|gif)$/i,
    8. type: 'asset',
    9. generator: {
    10. filename: 'assets/[hash][ext][query]'
    11. }
    12. }
    13. ],
    14. },
    15. };

    2、打包后观察效果和区别

    注意:判断临界值默认为 8KB

    1)大于 8KB 文件:发送一个单独的文件并导出 URL 地址【打包输出图片】

    2)小于 8KB 文件:导出一个 data URI(base64字符串)【打包后转为base64字符串】


    • 10、webpack 搭建开发环境

    • 问题:之前改代码,需重新打包才能运行查看,效率很低
    • 开发环境:配置 webpack-dev-server 快速开发应用程序
    • 作用:启动 Web 服务,自动检测代码变化,热更新到网页
    • 注意:dist 目录和打包内容是在内存里(更新快)【并非打包到根目录下
    • 官网地址指向:开发环境 | webpack 中文文档 (docschina.org)

    1、下载 webpack-dev-server 软件包到当前项目

        npm i webpack-dev-server--save-dev

    2、设置模式为开发模式,并配置自定义命令

    3、使用 npm run dev 来启动开发服务器,试试热更新效果

    • 11、webpack 的 打包模式

    打包模式:告知 Webpack 使用相应模式的内置优化

    1、在 webpack.config.js 配置文件设置 mode 选项

    2、在 package.json 命令行设置 mode 参数 

    注意:命令行设置的 优先级 高于 配置文件中的,推荐用命令行设置 


    • 12、webpack 打包模式的应用

    需求:在开发模式下用 style-loader 内嵌更快,在生产模式下提取 css 代码

    方案1:webpack.config.js 配置导出函数,但是局限性大(只接受 2 种模式)

    方案2:借助 cross-env (跨平台通用)包命令,设置参数区分环境

    1、下载 cross-env 软件包到当前项目

        npm i cross-env --save-dev

    2、配置自定义命令,传入参数名和值(会绑定到 process.env 对象下)

    1. 当你运行对应命令 npm run build 或者dev 时,根据 pageage.jsonNODE_ENV=??,执行
    2. cross-env :固定
    3. NODE_ENV=production :自定义的,也可以直接写 a=b,但是为了语义化点

    3、在 webpack.config.js 区分不同环境使用不同配置 

    1. process.env.NODE_ENV === 'development' ? 'style-loader' : MiniCssExtractPlugin.loader
    2. process.env :固定的,通过这个调用 我们定义的值


    • 13、前端-注入环境变量 

    • 需求:前端项目中 index.js 中,开发模式下打印语句生效,生产模式下打印语句失效
    • 问题:cross-env 设置的只在 Node.js 环境生效,前端代码无法访问 process.env.NODE_ENV
    • 解决:使用 Webpack 内置的 DefinePlugin 插件
    • 作用:在编译时,将前端代码中匹配的变量名,替换为值或表达式

    1. plugins: [
    2. new webpack.DefinePlugin({
    3. // 就是,在 前端项目 某个js文件 中,遇见 process.env.NODE_ENV 就赋值 给 模式对应的值
    4. 'process.env.NODE_ENV': JSON.stringify(process.env.NODE_ENV)
    5. })
    6. ],

    测试的结果:


    • 14、开发环境调错 - source map

    • 问题:代码被压缩和混淆,无法正确定位源代码位置(行数和列数)
    • source map可以准确追踪 error 和 warning 在原始代码的位置
    • 设置:webpack.config.js 配置 devtool 选项
    • inline-source-map 选项:把源码的位置信息一起打包在 js 文件内
    • 注意:source map 仅适于开发环境不要在生产环境使用(防止被轻易看源码位置)
    • 官网网址指向:Devtool | webpack 中文文档 (docschina.org)
    1. const config = {
    2. ...
    3. }
    4. // 开发环境下使用 sourcemap 选项
    5. if (process.env.NODE_ENV === 'development') {
    6. config.devtool = 'inline-source-map'
    7. }
    8. module.exports = config

    解决方法:下载 cross-env 软件包,根据 pageage.json 中设置的 环境变量,判断当前启动的是生产模式,还是开发模式


    • 15、解析别名 alias 【用 @ 来代表 src 绝对路径】

    • 解析别名:配置模块如何解析,创建 import 引入路径的别名,来确保模块引入变得更简单
    • 例如:原来路径如图,比较长而且相对路径不安全
    • 解决:在 webpack.config.js 中配置解析别名 @ 来代表 src 绝对路径
    • 官网网址指向:webpack 中文文档 (docschina.org)

    1. module.exports = {
    2. //...
    3. resolve: {
    4. // __dirname 获取的是 webpack.config.js 所在文件夹的绝对路径
    5. '@': path.resolve(__dirname, 'src')
    6. },
    7. };

    • 16、开发模式使用 npm 下载包 || 生产模式使用 CDN 引用

    • CDN定义:内容分发网络,指的是一组分布在各个地区的服务器
    • 作用:把静态资源文件/第三方库放在 CDN 网络中各个服务器中,供用户就近请求获取
    • 好处:减轻自己服务器请求压力,就近请求物理延迟低,配套缓存策略
    • cdn 引入网址:BootCDN - Bootstrap 中文网开源项目免费 CDN 加速服务

    需求:开发模式使用本地第三方库,生产模式下使用 CDN 加载引入 

    1、在 html 中引入第三方库的 CDN 地址 并用模板语法判断

    1. 下面这个是 htmlWebpackPlugin 规定的用法,我们后面在 options 定义 useCdn 的值 判断就行
    2. <% if(htmlWebpackPlugin.options.useCdn){ %>
    3. <link href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/5.2.3/css/bootstrap.min.css" rel="stylesheet">
    4. <% } %>

    2、配置 webpack.config.js 中 externals 外部扩展选项(防止某些 import 的包被打包

    1. const config = {
    2. plugins: [
    3. new HtmlWebpackPlugin({
    4. useCdn: process.env.NODE_ENV === 'production', // 生产模式下使用 cdn 引入的地址
    5. }),
    6. ]
    7. }
    8. // 生产环境下使用相关配置
    9. if (process.env.NODE_ENV === 'production') {
    10. // 外部扩展(让 webpack 防止 import 的包被打包进来)
    11. config.externals = {
    12. // key:import from 语句后面的字符串
    13. // value:留在原地的全局变量(最好和 cdn 在全局暴露的变量一致)
    14. 'bootstrap/dist/css/bootstrap.min.css': 'bootstrap',
    15. 'axios': 'axios',
    16. }
    17. }
    18. module.exports = config

    3、两种模式下打包观察效果 


    • 17、webpack 多页面打包

     多页面:多个 html 文件,切换页面实现不同业务逻辑展示

  • 相关阅读:
    数据结构 - 红黑树
    枚举类 typede fmalloc 函数   free 函数 位运算
    c语言,c++,java和python这些语言有何区别?编译型编程语言编译语言,解释型编程语言解释型语言
    HOT100打卡—day11—【贪心】—最新9.5(剩3题)
    神经网络准确率计算公式,神经网络预测精度
    机器人示教编程与离线编程的优缺点对比
    SSM+基于SSM的课堂考勤管理系统的设计与实现 毕业设计-附源码191617
    2023 年 API 安全状况
    MongoDB——将时间戳转换为日期
    手写一个react,看透react运行机制
  • 原文地址:https://blog.csdn.net/weixin_49931650/article/details/132806736