2024 年最新前端工程师使用 Webpack 模块打包工具详细教程(更新中)

news2025/1/26 15:45:48

概述 Webpack 模块打包工具

Webpack 是一个现代的静态模块打包工具,用于将前端应用程序的各种资源(例如如:JavaScript、CSS、图片等)视为模块,并将它们打包成可以在浏览器中运行的静态文件。它的主要功能包括模块打包、资源优化、代码分割、加载器转换等。

Webpack 官方网址:https://webpack.js.org/

在这里插入图片描述

Webpack 在内部会构建一个依赖图(dependency graph),这个依赖图映射到项目所需的每个模块,并生成一个或多个 bundle。在打包过程中,Webpack 可以进行各种优化,如代码压缩、文件合并、按需加载等,以提高应用程序的性能和加载速度。

Webpack 的配置包括入口(entry)、出口(output)、加载器(loader)和插件(plugins)。入口决定了 Webpack 从哪个模块开始生成依赖关系图,而出口则指定了生成的静态文件的输出目录。加载器用于转换不同类型的模块,以便能够被打包和引用,而插件则用于执行更广泛的任务,如代码分割、资源优化、生成 HTML 文件等。

为了进一步提高 Webpack 的打包速度,可以使用一些优化技巧,如使用线程加载器(例如:thread-loader)来启用多线程打包,或者使用缓存加载器来缓存已经编译过的文件,从而避免重复编译。总的来说,Webpack是一个强大而灵活的工具,能够帮助开发者更高效地构建和优化前端应用程序。

下载安装 Webpack 环境

安装 Node.js 环境

访问 Node.js 官网,下载并安装适合你操作系统的Node.js版本。安装完成后,你可以在命令行中运行 node -v 来检查 Node.js 是否安装成功,以及安装的版本。

初始化项目

在你的项目文件夹中,打开命令行窗口,并输入 npm init 来初始化一个新的 npm 项目。这会创建一个 package.json 文件,这个文件会保存你的项目依赖和其他配置信息。

全局安装 webpack webpack-cli

NPM 进行全局安装 webpack webpack-cli

npm install webpack webpack-cli -g

全局安装意味着你可以在任何地方使用 webpack 和 webpack-cli 命令。然而对于大多数项目,推荐进行局部安装,以避免不同项目之间的版本冲突。

局部安装 webpack webpack-cli

如果你选择局部安装在项目的根目录下运行如下:

npm install webpack webpack-cli --save-dev

这样 webpack 和 webpack-cli 就会被添加到你的 package.json 文件的 devDependencies 部分,成为项目的开发依赖。

使用 Webpack 流程图

配置 webpack.config.js 入口 entry 出口 output

const path = require("path")

module.exports = {
    entry: "./src/main.js",
    output: { 
        path: path.join(__dirname, "dist"),
        filename: "bundle.js"
    }
}

配置 package.json script 脚本

{
	"description": "",
	"scripts": {
		"build": "webpack"
	},
	"devDependencies": {
		"webpack": "^5.91.0",
		"webpack-cli": "^5.1.4"
	}
}

打包流程图
在这里插入图片描述

注意:所有要被打包的资源都要跟入口产生直接 / 间接的引用关系。

使用 Webpack 打包静态网页

Webpack 本身并不直接处理 HTML 文件,但是你可以使用 html-webpack-plugin 插件来简化静态 HTML 文件的打包过程。使用 html-webpack-plugin 来简化静态 index.html 文件的打包过程了。

如何使用 html-webpack-plugin 来打包静态 index.html 的步骤:

安装必要的插件和依赖

在你的项目中,首先确保已经安装了 webpack 和 webpack-cli。安装 html-webpack-plugin

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

配置 webpack.config.js

在你的 webpack.config.js 文件中,引入 html-webpack-plugin 并添加到 plugins 数组中:

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

module.exports = {
  plugins: [
    new HtmlWebpackPlugin({
      template: './src/index.html',
      filename: 'index.html',
    })
  ],
};

编写 index.html

在你的源代码目录(在这个例子中是 src)中,创建一个 index.html 文件。这个文件将被 html-webpack-plugin 用作模板,并且插件会自动将你的打包后的 JavaScript 文件(例如 main.js)注入到这个 HTML 文件中。

运行 webpack

当运行 webpack 构建过程时,html-webpack-plugin 会自动处理你的 index.html 文件,并将它输出到你的构建目录(默认为 dist)中。

注意事项

确保你的 HTML 文件中引用了正确的脚本和样式文件路径。在开发环境中,你可能直接引用 src 目录下的文件,但在生产环境中,这些文件会被 webpack 打包并输出到不同的位置。你可以使用 webpack 的 publicPath 配置项来确保引用路径正确。

如果你的项目中有多个 HTML 文件需要打包,你可以为每个文件创建一个 HtmlWebpackPlugin 实例,并在 plugins 数组中添加它们。

启动本地服务 webpack-dev-server

启动本地服务,可实时更新修改的代码,打包变化代码到内存中,然后直接提供端口和网页访问。也就是说以后改了 src 目录下的资源代码,就会直接更新到内存打包,然后反馈到浏览器上了。

下载 webpack-dev-server

npm install webpack-dev-server -D

配置 package.json 自定义脚本

scripts: {
	"build": "webpack",
	"serve": "webpack serve"
}

运行脚本启动 webpack 开发服务器

npm run serve

使用 Webpack 打包 css 文件

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

module.exports = {
    module: { 
        rules: [
	        {
				test: /\.css$/,
				use: [ "style-loader", "css-loader"]
	        }
        ]
    }
}

匹配所有的 css 文件,use数组里从右向左运行,先用 css-loader 让 webpack 能够识别 css 文件的内容并打包,再用 style-loader 将样式,把 css 插入到 dom 中。

总结:webpack 默认只认识 js 文件和 json 文件。万物皆模块,引到入口才会被 webpack 打包,css打包进 js 中,然后被嵌入在 style 标签插入 dom 上。

style-loader 文档:https://webpack.docschina.org/loaders/style-loader/
css-loader 文档:https://webpack.docschina.org/loaders/css-loader/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1586606.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

对 FileReader 的理解

1、文档 FileReader - Web API 接口参考 | MDN 2、概念 FileReader 对象是一个内置的 JavaScript 对象,用于在客户端(浏览器)中异步读取文件内容。 它提供了一种在 Web 应用程序中读取文件数据的方式,可以读取文件内容并将其转…

跟TED演讲学英文:The next grand challenge for AI by Jim Fan

The next grand challenge for AI Link: https://www.ted.com/talks/jim_fan_the_next_grand_challenge_for_ai? Speaker: Jim Fan Date: October 2023 文章目录 The next grand challenge for AIIntroductionVocabularyTranscriptSummary后记 Introduction Researcher Jim…

MySQL事务、主从、分库分表常见面试题

文章目录 1.事务的特性2.并发事务问题,如何解决,默认隔离级别3.undo log和redo log的区别4.事务中的隔离性是如何保证的(解释一下MVCC)5.主从同步原理6.分库分表 1.事务的特性 2.并发事务问题,如何解决,默认…

2022年蓝桥杯省赛软件类C/C++B组----积木画

想借着这一个题回顾一下动态规划问题的基本解法,让解题方法清晰有条理,希望更多的人可以更轻松的理解动态规划! 目录 【题目】 【本题解题思路】 【DP模版】 总体方针: 具体解题时的套路: 【题目】 【本题解题思…

压缩列表ziplist

目录 1压缩列表的结构 2.压缩列表节点的构成 previous_entry_length encodeing conent 3.压缩列表API 1.创建列表 ziplistNew 2.正向遍历 ziplistNext 3.反向遍历 ziplistPrev 4.插入元素 ziplistInsert 5.级联更新 __ziplistCascadeUpdate 6.删除节点 7.查找entr…

L2-2 巴音布鲁克永远的土(二分+并查集)

思路:我们可以二分答案,然后判断当前答案合不合理。 对于判断答案合理,可以用并查集,看mid能否把所有检查点连进一个集合中,枚举每个结点,如何当前结点周围的四个方向可以连的话,就加进同一个集…

host文件nginx代理 综合理解

之前一直理解得很糙 导致遇到问题很迷糊 今天经过大佬两句话讲明白了 特此记录 host文件 首先host做了代理 也就是对浏览器的DNS寻址做了拦截 具体原理可以参照当我们在地址栏输入URL的时候浏览器发生了什么 例如127.0.0.1 www.baidu.com 将 127.0.0.1 www.baidu.com 链接自…

DHCP抓包分析

DHCP动态路由配置协议,是C/S架构,由DHCP服务器为客户端动态分配IP信息。 DHCP客户端首次接入网络数据交互过程: 如何解决IP地址的冲突: ▫ DHCP服务器端:收到DHCP DISCOVER报文时,给客户端分配IP地址前会发…

有关NVIDIA 4090的pytorch版本安装心得

目录 1.查看版本2.安装对应版本的pytorch3.检测是否安装成功4.问题 1.查看版本 输入 nvidia-smi 查看GPU支持的cuda最高版本 如上图所示,你的GPU支持的最高CUDA版本便为12.2,所以你要安装CUDA版本不能高于该版本。安装版本不能太低,建议就小…

高阶流程图(SIPOC)

SIPOC高阶流程图是一种流程映射和改进方法,它使用可视化的方式描述一个或多个流程的输入和输出。SIPOC是五个单词的首字母缩写,分别代表供应商(Suppliers)、输入(Inputs)、过程(Processes&#…

python使用概率算法模拟寻找伴侣

对于模拟寻找伴侣的问题,人在特定时期内能够遇见的异性是有限的,假设在某段时期内能够遇见的异性人数是n,那么问题在于在不能全面对n位候选人进行评估的情况下,以最大概率选中最好的那位。 假设n位候选人的水平用n个不同的数值表示,数值越大表示其水平则越高,问题在于,…

深入剖析Tomcat(一) 实现一个简单的Web容器

前言 在Java生态中,Tomcat的应用可谓经久不衰,众多Java Web应用都依赖它来进行部署。 虽然我们经常使用它,但是如果不深入了解的话,它对我们来说就一直是一个黑盒。就单纯的作为一个使用者来说,肯定也知道它内部应用…

Win10下安装Anaconda

Anaconda是可以便捷获取包且对包能够进行管理,同时对环境可以统一管理的发行版本,它包含了conda、Python在内的超过180个科学包及其依赖项。 安装Anaconda Anaconda官方下载网址:https://www.anaconda.com/download 官网页面中&#xff0c…

探究 ChatGPT 的心脏--Transformer(基础知识第一篇)

Transformer 是 ChatGPT 的核心部分,如果将 AI 看做一辆高速运转的汽车,那么 Transformer 就是最重要的引擎。它是谷歌于 2017 年发表的《Attention is All You Need》中提出的 Sequence-to-sequence 的模型,诞生之后便一统江湖,在…

【考研数学】《660》+《880》高分搭配方法

📝《660题》和《880题》高效刷题方法 1️⃣做题要有针对性,不要为了做题而做题 💪660和880题虽然多,但是你不用全都做完,你可以把它当成是题源,里面的每一道题都很经典,如果搞懂一道&#xff…

51蓝桥杯之DS18B20

DS18B20 基础知识 代码流程实现 将官方提供例程文件添加到工程中 添加onewire.c文件到keil4里面 一些代码补充知识 代码 #include "reg52.h" #include "onewire.h" #include "absacc.h" unsigned char num[10]{0xc0,0xf9,0xa4,0xb0,0x99,…

最近一些前端面试问题整理

最近一些前端面试问题整理 4月8号1. TS 中的 类型别名 和接口的区别是什么?2. 什么是深拷贝和浅拷贝?深浅拷贝的方法有哪些?浅拷贝(Shallow Copy)深拷贝(Deep Copy)区别总结 3. 使用 JSON.strin…

如何在淘~宝接单和解决别人问题-java开发

如下这是一个连接:https://s.tb.cn/c.0vDtL3https://s.tb.cn/c.0vDtL3 解决各种问题。可付费咨询

炒股自动化:交易接口API才是重点,券商官方散户可用的接口

上一篇我们用get_full_tick取到了数据,也讲了变量和字典的基本概念,这次我们向交易所发送订单试试。前面文章的链接放在文末了,需要的可以看一下 这些内容是给新手看的,找接口的大佬们直接拉到文末即可 取市场数据的方法很多&am…