当前位置: 首页 > news >正文

【前端】Webpack5中Html和CSS的压缩打包

1.Webpack5简介

1.1.Webpack简介

在这里插入图片描述

(1)webpack的发展历程

  • 2012.3—webpack(问世)

  • 2014.2—webpack1

  • 2016.12—webpack2

  • 2017.6—webpack3

  • 2018.2—webpack4

  • 2020.10—webpack5(要求node版本10.13+)

(2)什么是webpack

  • webpack 是一个用于现代 JavaScript 应用程序的静态模块打包工具

  • 静态模块

    • 模块化开发,避免重复代码、 逻辑,提高开发效率
  • 打包

    • 将各个模块,按照一定的规则组装起来

在这里插入图片描述

  • 将多个不同类型文件打包
  • 编译代码,确保浏览器能解析
  • 对代码进行压缩,减少文件体积,提高加载速度
  • 对源代码进行格式化校验
  • 有热更新功能,提高开发效率
  • 不同环境,提供不同的打包策略
1.2.Webpack五个核心配置

(1)入口(entry)

入口起点(entry point) 指示 webpack 应该使用哪个模块,来作为构建其内部依赖图(dependency graph)的开始。进入入口起点后,webpack 会找出有哪些模块和库是入口起点(直接和间接)依赖的。

默认值是 ./src/index.js,但你可以通过在 webpack configuration中配置 entry 属性,来指定一个(或多个)不同的入口起点。

在这里插入图片描述

(2)输出(output)

output 属性告诉 webpack 在哪里输出它所创建的 bundle,以及如何命名这些文件。主要输出文件的默认值是 ./dist/main.js,其他生成文件默认放置在 ./dist 文件夹中。

在这里插入图片描述

(3)加载器(Loader)

webpack 只能理解 JavaScript 和 JSON 文件,这是 webpack 开箱可用的自带能力。loader 让 webpack 能够去处理其他类型的文件,并将它们转换为有效 模块,以供应用程序使用,以及被添加到依赖图中。

webpack 的其中一个强大的特性就是能通过 import 导入任何类型的模块(例如 .css 文件),其他打包程序或任务执行器的可能并不支持。我们认为这种语言扩展是很有必要的,因为这可以使开发人员创建出更准确的依赖关系图。

在更高层面,在 webpack 的配置中,loader 有两个属性:

  • test 属性,识别出哪些文件会被转换。
  • use 属性,定义出在进行转换时,应该使用哪个 loader。

在这里插入图片描述

(4)插件(plugin)

loader 用于转换某些类型的模块,而插件则可以用于执行范围更广的任务。包括:打包优化,资源管理,注入环境变量。

想要使用一个插件,你只需要 require() 它,然后把它添加到 plugins 数组中。多数插件可以通过选项(option)自定义。你也可以在一个配置文件中因为不同目的而多次使用同一个插件,这时需要通过使用 new 操作符来创建一个插件实例。

在这里插入图片描述

(5)模式(mode)

通过选择 development, productionnone 之中的一个,来设置 mode 参数,你可以启用 webpack 内置在相应环境下的优化。其默认值为 production

在这里插入图片描述

1.3.webpack初体验

(1)初始化项目

cnpm init -y

(2)安装webpack

cnpm i webpack webpack-cli -D

(3)创建入口文件

在这里插入图片描述

console.log('hello webpack');

(4)打包,指定mode

webpack ./js/index.js -o ./dist --mode=development

在这里插入图片描述

2.HTML、CSS资源打包

2.1.理解webpack配置文件

(1)webpack配置文件的作用

  • 简化命令行的选项

  • 默认配置文件名称为webpack.config.js

  • 操作webpack大部分都是在配置webpack.config.js文件

(2)配置详情

  • mode(模式)
// 打包模式配置
mode: 'development',
  • entry(入口)
// 入口文件配置
entry: './src/index.js',
  • output(出口)
const { resolve } = require('path');// 出口文件配置
output: {// 所有输出文件的目标路径,必须是绝对路径path: path.resolve(__dirname, 'dist'),// 出口文件名配置filename: "bundle.js",
},
  • module(模块-loader配置)
// 模块配置
module: {rules: [// 配置多个模块规则(配置loader、解析器等选项)],
},
  • devServer(用于快速开发应用程序)
// 开发服务器
devServer: {},
  • plugin(插件)
// 插件配置
plugins: [],

创建webpack.config.js配置文件

const { resolve } = require("path");module.exports = {// 打包模式配置mode: "development",// 入口文件配置entry: "./js/index.js",// 出口文件配置output: {// 所有输出文件的目标路径,必须是绝对路径path:resolve(__dirname, "dist"),// 出口文件名配置filename: "main.js",},// 模块配置module: {rules: [// 配置多个模块规则(配置loader、解析器等选项)],},// 开发服务器devServer: {},// 插件配置plugins: [],
};

执行命令

npm run build

在这里插入图片描述

2.2.自动生成HTML文件和指定模板

自动生成HTML文件(html-webpack-plugin),该插件可以生成一个 HTML 文件,并在HTML中加载所有打包资源,便于服务器访问。

(1)安装

cnpm i html-webpack-plugin -D

(2)在webpack.config.js中引入插件

const HtmlWebpackPlugin = require('html-webpack-plugin')

(3)webpack.config.js配置plugins

plugins: [new HtmlWebpackPlugin(),
],

执行 npm run build

在这里插入图片描述

指定生成HTML模板

(1)新建HTML文件

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title><%=htmlWebpackPlugin.options.title%></title>
</head>
<body></body>
</html>

注意title这块要用EJS语法,是JS的模板引擎。

(2)配置plugins

plugins: [new HtmlWebpackPlugin({template:'./html/index.html',  //指定 html 模板filename:'index.html',				//指定 html 名称title:'hello webpack'					//指定 html title}),
],

执行 npm run build

在这里插入图片描述

2.3.打包多个HTML页面和压缩

(1)打包多个HTML页面

plugins: [new HtmlWebpackPlugin({template:'./html/index.html',  filename:'one.html',				title:'第一个'					}),new HtmlWebpackPlugin({template:'./html/index.html',  filename:'two.html',				title:'第二个'					}),
],

在这里插入图片描述

(2)压缩html

  plugins: [new HtmlWebpackPlugin({template:'./html/index.html',  filename:'index.html',				title:'index',minify: {collapseWhitespace: true,  // 清除空格换行removeComments: true,			 // 清除注释}, 				})],

在这里插入图片描述

2.4.CSS文件打包原理

打包css文件需要两个loader:

  • css-loader

    • 将css代码转化为js代码,合并到打包后的js文件中。
  • style-loader

    • 将包含css内容的js代码,插入到html中style标签中。

(1)安装css-loader和style-loader

cnpm i css-loader style-loader -D

(2)将创建的css文件引入到js文件中

创建css文件

.d1{background-color: cadetblue;
}//html 中 加入一个div元素<div class="d1">我是李祥</div>
import './css/main.css'
console.log('hello webpack');

(3)webpack.config.js配置module

// 模块配置
module: {rules: [// 配置多个模块规则(配置loader、解析器等选项){// 匹配css文件test: /\.css$/i,// 指定加载器,加载顺序是从左到右或者是从下到上use: ['style-loader', 'css-loader'],},],
},

在这里插入图片描述

2.5.将CSS代码抽离成单独文件

CSS代码抽离成单独文件的作用:

  • 从js文件中抽离出css代码,减少js文件体积
  • 当js文件比较庞大时,可以避免阻碍页面的渲染
  • 提高渲染速度

将CSS代码抽离成单独文件的插件mini-css-extract-plugin

(1)安装mini-css-extract-plugin

cnpm i mini-css-extract-plugin -D

(2)webpack.config.js引入

const MiniCssExtractPlugin=require('mini-css-extract-plugin')

(3)loader配置(替换style-loader)

use:[MiniCssExtractPlugin.loader,'css-loader']

(4)实例化插件

new MiniCssExtractPlugin({filename:'./css/main.css'
})

在这里插入图片描述

2.6.打包CSS预编译语言

(1)安装css预编译语言插件

  • less
cnpm install less less-loader -D
  • sass
cnpm install node-sass sass-loader -D
  • stylus
cnpm install stylus stylus-loader -D

(2)同样js引入less文件,webpack配置文件中配置规则

 // 模块配置
module: {rules: [{test: /\.less$/i,use: ['style-loader', 'css-loader', 'less-loader'],},],
},
2.7.CSS样式添加兼容前缀

(1)安装插件

cnpm i postcss-loader autoprefixer -D

(2)配置

  • webpack.config.js

    use: [MiniCssExtractPlugin.loader, 'css-loader','postcss-loader'   // 处理css兼容
    ]
    
  • postcss.config.js

    module.exports = {plugins: [require('autoprefixer')], // 添加浏览器前缀
    };
    
  • package.json

    "browserslist":["last 2 version",   // 兼容浏览器的最近两个版本"> 1%"							// 全球占有率超过1%的浏览器
    ]
    

作用:让特殊的css样式兼容各个浏览器

相关文章:

【前端】Webpack5中Html和CSS的压缩打包

1.Webpack5简介 1.1.Webpack简介 &#xff08;1&#xff09;webpack的发展历程 2012.3—webpack&#xff08;问世&#xff09; 2014.2—webpack1 2016.12—webpack2 2017.6—webpack3 2018.2—webpack4 2020.10—webpack5&#xff08;要求node版本10.13&#xff09; &a…...

postman接收后端返回的文件流并自动下载

不要点send&#xff0c;点send and download&#xff0c;postman接受完文件流会弹出文件保存框让你选择保存路径...

谈谈Net-SNMP软件

Net-SNMP是一个开源的SNMP软件套件&#xff0c;它提供了SNMP代理&#xff08;snmpd&#xff09;和SNMP工具&#xff08;如snmpget、snmpwalk等&#xff09;&#xff0c;可以用于监控和管理网络设备。 Net-SNMP最初是从UC Davis的SNMP软件衍生而来&#xff0c;现在已经成为广泛…...

前端对普通数字数组排序示例

1. arr.sort(fn) // 升序排序arr.sort((a, b) > a - b);// 降序排序arr.sort((a, b) > b - a); 2. 冒泡排序 冒泡排序-升序原理: eg: [1, 6, 7, 9, 10, 3, 4, 5, 2] 1) 先遍历第一遍数组, 前一个数字大于后一个数字, 就交换位置, 最后最大值10放在数组的最后, 此时是…...

SQL server中:常见问题汇总(如:修改表时不允许修改表结构、将截断字符串或二进制数据等)

SQL server中&#xff1a;常见问题汇总 1.修改表时提示&#xff1a;不允许修改表结构步骤图例注意 2.将截断字符串或二进制数据。3.在将 varchar 值 null 转换成数据类型 int 时失败。4.插入insert 、更新update、删除drop数据失败&#xff0c;主外键FOREIGN KEY 冲突5.列不允许…...

无线通信中CSI的含义

在无线通信中&#xff0c;CSI代表"Channel State Information"&#xff0c;即信道状态信息。CSI是一种关键的信息&#xff0c;用于评估和描述通信信道的特性&#xff0c;以帮助发送器和接收器在通信过程中做出智能的调整和决策。 CSI包括有关通信信道的以下信息&…...

如何一键核实验证身份证的真伪?

据报道&#xff0c;今年10月10日&#xff0c;广东省佛山市朱某因生活琐事与丈夫发生争吵&#xff0c;民警发现她的身份证有问题。 在民警打算进一步了解情况&#xff0c;查看夫妻二人的身份证件时&#xff0c;朱某的身份证引起了民警的注意。这张身份证表面很光滑&#xff0c;…...

冒泡排序:了解原理与实现

目录 原理 实现 性能分析 结论 冒泡排序&#xff08;Bubble Sort&#xff09;是一种简单但效率较低的排序算法。它重复地比较相邻的元素并交换位置&#xff0c;直到整个序列有序为止。虽然冒泡排序的时间复杂度较高&#xff0c;但在小规模数据集上仍然具有一定的实际应用价…...

springboot maven项目环境搭建idea

springboot maven项目环境搭建idea 文章目录 springboot maven项目环境搭建idea用到的软件idea下载和安装java下载和安装maven下载和安装安装maven添加JAVA_HOME路径&#xff0c;增加JRE环境修改conf/settings.xml&#xff0c;请参考以下 项目idea配置打开现有项目run或build打…...

vue3检测是手机还是pc端,监测视图窗口变化

1.超小屏幕&#xff08;手机&#xff09; 768px以下 2.小屏设备&#xff08;平板&#xff09; 768px-992px 3.中等屏幕&#xff08;旧式电脑&#xff09; 992px-1200px 4.大屏设备&#xff08;现代电脑&#xff09; 1200px以上 <script setup name"welcome"> i…...

B - Magical Subsequence (CCPC2021哈尔滨)

思路&#xff1a; &#xff08;1&#xff09;问题&#xff1a;对于已知数组&#xff0c;每组依次选两个&#xff0c;尽量选更多组&#xff0c;选的每组和相等&#xff1b;&#xff08;假定和为x) &#xff08;2&#xff09;于是问题拆分为两步&#xff0c; x是多少x确定时&a…...

Leetcode刷题详解——x的平方根

1. 题目链接&#xff1a;69. x 的平方根 2. 题目描述&#xff1a; 给你一个非负整数 x &#xff0c;计算并返回 x 的 算术平方根 。 由于返回类型是整数&#xff0c;结果只保留 整数部分 &#xff0c;小数部分将被 舍去 。 **注意&#xff1a;**不允许使用任何内置指数函数和…...

windows安装docker,解决require wsl 2问题

想在windows上安装桌面版docker&#xff0c;上官网下载了安装包&#xff0c;安装完后&#xff0c;启动报错&#xff0c;忘了截图了。 大概意思就是require wsl 2。 于是就是docker FAQ中找相关问题解决方案&#xff0c;点&#xff0c;点&#xff0c;点然后就点到微软了。 ws…...

建立复数类

目录 程序设计 程序分析 系列文章 在课堂示例的基础上,显示复数时如果虚部为0时只显示实部,实部为0时只显示虚部,虚部为负数时以a-bi的形式显示,并为复数类增加减法功能。 程序设计 Work4类: package work;import java.util.Scanner;public class Work4 {private in…...

docker部署prometheus+grafana服务器监控(三) - 配置grafana

查看 prometheus 访问 http://ip:9090/targets&#xff0c;效果如下&#xff0c;上面我们通过 node_exporter 收集的节点状态是 up 状态。 配置 Grafana 访问 http://ip:3000&#xff0c;登录 Grafana&#xff0c;默认的账号密码是 admin:admin&#xff0c;首次登录需要修改…...

面试题:说一下加密后的数据如何进行模糊查询?

文章目录 正文如何对加密后的数据进行模糊查询沙雕做法沙雕一沙雕二 常规做法常规一常规二超神做法 总结 正文 我们知道加密后的数据对模糊查询不是很友好&#xff0c;本篇就针对加密数据模糊查询这个问题来展开讲一讲实现的思路&#xff0c;希望对大家有所启发。 为了数据安…...

LeetCode75——Day15

文章目录 一、题目二、题解 一、题目 1456. Maximum Number of Vowels in a Substring of Given Length Given a string s and an integer k, return the maximum number of vowel letters in any substring of s with length k. Vowel letters in English are ‘a’, ‘e’…...

Qwt开发环境搭建(保姆级教程)

1.简介 QWT&#xff0c;即Qt Widgets for Technical Applications&#xff0c;其目标是以基于2D方式的窗体部件来显示数据&#xff0c; 数据源以数值&#xff0c;数组或一组浮点数等方式提供&#xff0c; 输出方式可以是Curves&#xff08;曲线&#xff09;&#xff0c;Slider…...

【供应链】仓储、物流、车辆管理

...

从另外一个进程中读取数据

从另外一个进程中读取数据&#xff0c;其实就注入线程&#xff0c;寻址&#xff0c;解析内存&#xff0c;处理数据。例如这个就是从另外一个正在运行的进程中&#xff0c;读取数据并保存。实时性还可以。...

conda相比python好处

Conda 作为 Python 的环境和包管理工具&#xff0c;相比原生 Python 生态&#xff08;如 pip 虚拟环境&#xff09;有许多独特优势&#xff0c;尤其在多项目管理、依赖处理和跨平台兼容性等方面表现更优。以下是 Conda 的核心好处&#xff1a; 一、一站式环境管理&#xff1a…...

使用VSCode开发Django指南

使用VSCode开发Django指南 一、概述 Django 是一个高级 Python 框架&#xff0c;专为快速、安全和可扩展的 Web 开发而设计。Django 包含对 URL 路由、页面模板和数据处理的丰富支持。 本文将创建一个简单的 Django 应用&#xff0c;其中包含三个使用通用基本模板的页面。在此…...

工程地质软件市场:发展现状、趋势与策略建议

一、引言 在工程建设领域&#xff0c;准确把握地质条件是确保项目顺利推进和安全运营的关键。工程地质软件作为处理、分析、模拟和展示工程地质数据的重要工具&#xff0c;正发挥着日益重要的作用。它凭借强大的数据处理能力、三维建模功能、空间分析工具和可视化展示手段&…...

MODBUS TCP转CANopen 技术赋能高效协同作业

在现代工业自动化领域&#xff0c;MODBUS TCP和CANopen两种通讯协议因其稳定性和高效性被广泛应用于各种设备和系统中。而随着科技的不断进步&#xff0c;这两种通讯协议也正在被逐步融合&#xff0c;形成了一种新型的通讯方式——开疆智能MODBUS TCP转CANopen网关KJ-TCPC-CANP…...

【7色560页】职场可视化逻辑图高级数据分析PPT模版

7种色调职场工作汇报PPT&#xff0c;橙蓝、黑红、红蓝、蓝橙灰、浅蓝、浅绿、深蓝七种色调模版 【7色560页】职场可视化逻辑图高级数据分析PPT模版&#xff1a;职场可视化逻辑图分析PPT模版https://pan.quark.cn/s/78aeabbd92d1...

uniapp手机号一键登录保姆级教程(包含前端和后端)

目录 前置条件创建uniapp项目并关联uniClound云空间开启一键登录模块并开通一键登录服务编写云函数并上传部署获取手机号流程(第一种) 前端直接调用云函数获取手机号&#xff08;第三种&#xff09;后台调用云函数获取手机号 错误码常见问题 前置条件 手机安装有sim卡手机开启…...

6️⃣Go 语言中的哈希、加密与序列化:通往区块链世界的钥匙

Go 语言中的哈希、加密与序列化:通往区块链世界的钥匙 一、前言:离区块链还有多远? 区块链听起来可能遥不可及,似乎是只有密码学专家和资深工程师才能涉足的领域。但事实上,构建一个区块链的核心并不复杂,尤其当你已经掌握了一门系统编程语言,比如 Go。 要真正理解区…...

篇章二 论坛系统——系统设计

目录 2.系统设计 2.1 技术选型 2.2 设计数据库结构 2.2.1 数据库实体 1. 数据库设计 1.1 数据库名: forum db 1.2 表的设计 1.3 编写SQL 2.系统设计 2.1 技术选型 2.2 设计数据库结构 2.2.1 数据库实体 通过需求分析获得概念类并结合业务实现过程中的技术需要&#x…...

Java 与 MySQL 性能优化:MySQL 慢 SQL 诊断与分析方法详解

文章目录 一、开启慢查询日志&#xff0c;定位耗时SQL1.1 查看慢查询日志是否开启1.2 临时开启慢查询日志1.3 永久开启慢查询日志1.4 分析慢查询日志 二、使用EXPLAIN分析SQL执行计划2.1 EXPLAIN的基本使用2.2 EXPLAIN分析案例2.3 根据EXPLAIN结果优化SQL 三、使用SHOW PROFILE…...

欢乐熊大话蓝牙知识17:多连接 BLE 怎么设计服务不会乱?分层思维来救场!

多连接 BLE 怎么设计服务不会乱&#xff1f;分层思维来救场&#xff01; 作者按&#xff1a; 你是不是也遇到过 BLE 多连接时&#xff0c;调试现场像网吧“掉线风暴”&#xff1f; 温度传感器连上了&#xff0c;心率带丢了&#xff1b;一边 OTA 更新&#xff0c;一边通知卡壳。…...