什么是webpack
本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler)。当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个 bundle。详细使用可参考官方文档。
安装
在官网中给出了两种安装方式:
全局安装
局部安装
因为全局安装webpack时,会将项目中的webpack锁定到指定版本,并且在使用不同的webpack版本的项目中,可能会导致构建失败,所以官网中不推荐使用全局安装,我们接下来也是使用局部安装。
项目初始化以后执行安装命令: npm i webpack webpack-cli -D
安装以后,查看安装版本
此时会发现,直接执行webpack -v会报错,因为只是针对全局的命令,项目里面的话,需要借助npx,包括后面的其他webpack相关命令也是这样的。
安装完成以后,在项目根目录新建文件夹src,然后在src下新建index.js文件。
做了最简单的操作以后,就可以进行打包了:
这里使用命令npx webpack进行打包,没有指定入口文件,代表采用默认路径下(根目录-->src-->index.js)的文件作为入口文件,如果要采用其他文件作为入口文件,则需要在打包是进行指定:
上面这个就是指定根目录下的test.js作为入口文件。
打包完成以后,就会在根目录下生成一个dist文件夹。
webpack配置文件
默认配置文件
在上面的简单操作中,我们没有对项目进行任何配置,这种零配置的项目是很弱的,在正常项目中,总会根据特定的需求进行相应的配置。
刚刚执行命令npx webpack test.js时,表示使用根目录下的test.js为入口文件进行打包处理,默认打包后的模块名称为main.js,放在根目录下的dist文件夹下。零配置的话,全部都是默认的,要想进行自定义,就需要使用到webpack的配置文件进行自己想要的配置。
webpack有默认的配置文件webpack.config.js,刚刚上面的两个打包命令:
都没有指定配置文件,则代表使用默认的配置文件webpack.config.js进行打包(上面项目中不存在webpack.config.js这个文件,则表示零配置。如果项目中存在这个配置文件,并且打包的时候,没有指定配置文件,那么就会默认选中webpack.config.js)。
自定义配置文件
除了上面的默认配置文件以外,我们也可以自定义一个配置文件,然后在打包的时候进行指定就可以了:
这个就表示指定使用webpackconfig.js文件作为配置文件进行打包。
webpack.config.js
const path = require("path"); module.exports={ mode:'development', //模式:none development production // entry:"./src/index.js", //入口文件,不指定打包后的名称,则默认为main.js entry:{ main:"./src/index.js" //指定打包后的文件名称为main.js }, output:{ path:path.resolve(__dirname,'dist'), //打包后的文件存放的位置,必须是绝对路径 filename:"[name].js" //打包后的文件的名称,[]表示占位符,表示此处使用前面指定的名称,如果这里进行指定,则会覆盖前面的指定 } }
除了上面这些简单配置外,还可以修改打包命令,只需要修改package.json里的scripts就可以了。
修改为:
此时,我们就可以执行命令npm run bundle进行打包了。(因为npm run执行的命令,会优先使用项目工程里的包,效果和npx类似,所以这里不需要使用添加npx)
loader和module
loader是模块转换器,用于把模块原内容按照需求转换成新内容。webpack是模块打包工具,而模块不仅仅是js,还可以使css、图片或者其他格式,但是webpack默认只知道如何处理js模块,那么其他格式的模块处理,就需要借助于loader了(loader里的配置,单个是对象,多个用数组,遵循自右向左,从下到上的顺序)。
module是模块,在webpack里一切皆模块,一个模块对应着一个文件。webpack会从配置的Entry开始递归找出所有依赖的模块。
当webpack处理到不认识的模块时,需要在webpack中的module处进行配置,当检测到时什么格式的模块,就使用什么loader来处理。
上面,在入口文件中引入了一个图片模块以后,在进行打包,就直接报错了,这个时候,我们就需要使用到一个file-loader了。
file-loader
处理静态资源模块,就是当我们需要模块(txt、svg、csv、excel、图片等)仅仅是从源代码移动到打包目录的时候,就可以使用file-loader来处理了。其作用原理就是把打包入口中识别出的资源模块,移动到输出目录,并且返回一个地址名称。
要使用file-loader,首先需要进行安装:npm install file-loader -D
然后在配置文件webpack.config.js中配置使用:
再执行上面的打包操作:
最后的打包文件中,除了默认的出口文件外,还多了一个图片资源,就是上面引入的那个图片。但是此时有个问题,这个图片的名称改变了,因此,我们还需要进行相关的配置options。
url-loader
可以处理file-loader所有的事情,但是遇到jpg格式的模块,会把该图片转换成base64格式字符串,并打包到引入的js里。对小体积的图片比较合适,大图片就不合适了。
css-loader、style-loader和sass-loader
- css-loader用于分析css模块之间的关系,并合并成一个css
- style-loader会把css-loader生成的内容,以style挂载到页面的head部分
- sass-loader用于把sass语法转换成css,依赖node-sass模块
更多loader配置,可以参看官网loader介绍列表。
Plugins
plugin可以在webpack运行到某个阶段的时候,帮你做一些事情,类似于生命周期的概念。
html-webpack-plugin
html-webpack-plugin会在打包结束后,自动生成一个html文件,并把打包生成的js模块引入到该html中。
首先安装进行安装:npm install --save-dev html-webpack-plugin
并在项目根目录下新建一index.html
然后在配置文件中进行相关配置:
最后进行打包:
其中的app.html就是按照上面的配置生成的:
多入口配置
在上面配置的基础上,我们在src下新建两个js,然后在入口处进行配置:
然后打包,此时在dist文件下对应生成了3个出口文件,但是,在app.html文件中,却只引入了一个。
多出口配置
这样生成的每个html文件里,相应引入配置的js文件了。
clean-webpack-plugin
目前,我们每次进行打包的时候,都需要先删除dist文件夹,然后再打包,否则之前同名的文件被覆盖了,但是不同名的文件会被保留。现在clean-webpack-plugin就可以替我们完成打包前的清除工作。
首先进行安装:
npm install --save-dev clean-webpack-plugin
然后使用就可以了
mini-css-extract-plugin
前面style-loader会把css-loader生成的内容,以style挂载到页面的head部分。这里mini-css-extract-plugin这是将css形成一个单独的文档。
首先进行安装:npm install --save-dev mini-css-extract-plugin
然后引入并使用: