什么是webpack?
webpack 是前端的一个项目构建工具,它是基于 Node.js 开发出来的一个前端工具;
- 使用Gulp, 是基于 task 任务的,适合构建小型项目
- 使用Webpack, 是基于整个项目进行构建的;
- 借助于webpack这个前端自动化构建工具,可以完美实现资源的合并、打包、压缩、混淆等诸多功能。
- 根据官网的图片介绍webpack打包的过程
- webpack官网
webpack安装的两种方式
- 运行
npm i webpack -g
全局安装webpack,这样就能在全局使用webpack的命令 - 在项目根目录中运行
npm i webpack --save-dev
安装到项目依赖中(webpack最新版为4,教程为3)(--save-dev参数缩写为 -D)npm i webpack -D
【推荐】 -
webpack-安装踩坑
webpack的核心概念
-
Entry
- 代码的入口
- 打包的入口
- 单个或多个
-
Output
- 打包成的文件(bundle)
- 一个或多个
- 自定义规则
- 配合CDN
-
Loaders
- 处理文件
- 转化为模块
-
Plugins
- 参与打包整个过程
- 打包优化和压缩
- 配置编译时的变量
- 极其灵活
Entry
Output
Loaders
Plugins
webpack的基本使用
打包文件
- 建立了目录结构后,使用npm安装jQuery:
npm init -y
然后npm i jquery -S
- .写main.js后, 输入命令编译js,
webpack .\src\main.js -o .\dist\bundle.js
一些bug
解决:Error: Cannot find module 'webpack'
运行webpack报错:Cannot read property 'presetToOptions' of undefined
Webpack 3.X - 4.X 升级记录
webpack打包错误 ERROR in multi ./src/main.js ./dist/bundle.js
webpack基本配置
-
webpack.config.js
-
webpack-dev-server
为了实现自动打包,监听代码变化
可能遇到的问题
解决方案
webpack-dev-server配置命令的方式
-
--open
自动打开浏览器 -
--port 8000
指定端口 -
--contentBase src
内容的根路径 -
--hot
热重载热更新(不重新生成bundle.js,只生成补丁代码),实现浏览器不刷新重载(否则会页面整体刷新)
html-webpack-plugin插件
在内存中生成html页面的插件
安装
1.npm i html-webpack-plugin -D
2.在webpack.config.js导入插件
3.配置
优点
- 指定生成页面的名称,重名即可,会自动访问同名的内存的页面。
- 当使用 html-webpack-plugin之后,不再需要手动处理bundle.js的引用路径, 因为插件自动创建了一个合适的 script, 并引用了正确的路径
webpack中使用CSS(loader的使用)
- 在main.js中import CSS样式表,webpack默认只能打包JS类型的文件,需要手动安装一些合适的第三方loader加载器。
- 运行
cnpm i style-loader css-loader --save-dev
- 修改
webpack.config.js
这个配置文件:
module: { // 用来配置第三方loader模块的
rules: [ // 文件的匹配规则
{ test: /\.css$/, use: ['style-loader', 'css-loader'] }//处理css文件的规则
]
}
- 注意:
use
表示使用哪些模块来处理test
所匹配到的文件;use
中相关loader模块的调用顺序是从后向前调用的;
使用webpack打包less文件
- 运行
cnpm i less-loader less -D
- 修改
webpack.config.js
这个配置文件:
{ test: /\.less$/, use: ['style-loader', 'css-loader', 'less-loader'] },
使用webpack打包sass文件
- 运行
cnpm i sass-loader node-sass --save-dev
- 在
webpack.config.js
中添加处理sass文件的loader模块:
{ test: /\.scss$/, use: ['style-loader', 'css-loader', 'sass-loader'] }
url-loader处理图片和字体
默认情况下,webpack无法处理css文件中的url地址,不管是图片还是字体库
- 运行
cnpm i url-loader file-loader --save-dev
(file-loader为url-loader的内部依赖,不需要配置) - 在
webpack.config.js
中添加处理url路径的loader模块:
{ test: /\.(png|jpg|gif|jpeg)$/, use: 'url-loader' }
-
url-loader会自动把图片转为base64编码,可以通过
limit
指定进行base64编码的图片大小;只有小于指定字节(byte)的图片才会进行base64编码:
- 图片
{ test: /\.(png|jpg|gif)$/, use: 'url-loader?limit=43960' },
- 字体
{test:/\.(ttf|eot|svg|woff|woff2)$/,use:'url-loader'}
默认改变图片的名字的原因是:防止重名,可以传参改变这一默认行为
url-loader?limit=1024&name=[name].[ext]
,但为了防止重名,可以在原名字前添加hash值url-loader?limit=1024&name=[hash:8]-[name].[ext]
,hash最大为32位,所以最大只能设为32;
webpack.config.js 的 rules中的所有loader都能传参
webpack处理第三方文件的过程
-
发现处理的文件不是JS,就去配置文件查找有没有对应的第三方loader规则;
-
如果能发现对应的规则,就会调用对应的loader处理这种文件类型;
-
style-loader 与 css-loader 调用规则是从右到左调用。
-
当最后的一个loader调用完毕,会把处理的结果交给webpack进行打包合并,最终打包构件;
网友评论