首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
webpack介绍
安装webpack
webpack实现hello world
webpack配置文件
webpack 插件
使用 loader 处理 CSS 和 Sass
webpack-dev-server
webpack配置 react 开发环境
clean-webpack-plugin插件
webpack配置多个 HTML 文件
使用 pug (jade) 作为 HTML模板
热替换 HMR 处理 CSS
生产环境 vs 开发环境
webpack打包图片
webpack打包Bootstrap
ProvidePlugin 插件处理第三方包
理解devtool: 'source-map'
生产环境与开发环境配置文件分离
当前位置:
首页>>
技术小册>>
Webpack零基础入门
小册名称:Webpack零基础入门
这节主要来实践如何加载和打包 Twitter Bootstrap 框架。 ### 准备工作 先来复制一些 bootstrap 的代码片断。 src/index.html ``` <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <body> <button type="button" class="btn btn-default" aria-label="Left Align"> <span class="glyphicon glyphicon-align-left" aria-hidden="true"></span> </button> <button type="button" class="btn btn-default btn-lg"> <span class="glyphicon glyphicon-star" aria-hidden="true"></span> Star </button> <!-- Button trigger modal --> <button type="button" class="btn btn-primary btn-lg" data-toggle="modal" data-target="#myModal"> Launch demo modal </button> <!-- Modal --> <div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel"> <div class="modal-dialog" role="document"> <div class="modal-content"> <div class="modal-header"> <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button> <h4 class="modal-title" id="myModalLabel">Modal title</h4> </div> <div class="modal-body"> ... </div> <div class="modal-footer"> <button type="button" class="btn btn-default" data-dismiss="modal">Close</button> <button type="button" class="btn btn-primary">Save changes</button> </div> </div> </div> </div> </body> </html> ``` 注意,本节使用的是 bootstrap 3,因为目前写这篇文章时,bootstrap 4 还没出正式版,所以我们用 bootstrap 3。 效果如下: ![](/uploads/images/20230703/7be3a11c956e32c4a61b9d45394bdeec.png) 图标没显示出来,css 也没加载到,js 更是不可用。 ### 安装 bootstrap-loader 要加载 bootstrap 框架,主要是使用这个这个 loader:bootstrap-loader。 现在主要通过查看它的官方文档,来了解如何安装和使用它。 安装。 ``` $ npm install bootstrap-loader --save-dev $ npm install resolve-url-loader url-loader --save-dev ``` ### 使用 接下来,我们来看如何使用 bootstrap-loader 这个 loader。 3.1 创建 .bootstraprc 文件 在项目根目录下,创建 .bootstraprc 文件,其内容拷贝于下面这个链接的内容。 .bootstraprc-3-default 这个内容是官方提供的,主要存放的是 bootstrap 的配置选项,就是通过它来控制一些 bootstrap 的功能。 3.2 创建 webpack.bootstrap.config.js 文件 然后在项目根目录下,创建 webpack.bootstrap.config.js 文件,其内容拷贝于下面这个链接的内容。 webpack.bootstrap.config.js 这个内容是官方提供的,主要存放的是关于 bootstrap 的 webpack 配置的内容,它包含生产环境和开发环境的配置。 3.3 引用 boostrap 的 webpack 配置 现在我们把刚才下载的 webpack.bootstrap.config.js 文件利用起来。 webpack.config.js ``` const bootstrapEntryPoints = require('./webpack.bootstrap.config') var bootstrapConfig = isProd ? bootstrapEntryPoints.prod : bootstrapEntryPoints.dev; module.exports = { entry: { "app.bundle": './src/app.js', "contact": './src/contact.js', "bootstrap": bootstrapConfig }, ... } ``` 运行一下 npm run dev,发现报了个错。 ![](/uploads/images/20230703/4232af7de5f2660baae5f129de2af9e8.png) 字体文件没处理好。 通过查看 bootstrap-loader 官方的 readme 文档,加上下面几行 loader 的配置,可解决问题。 ``` module: { loaders: [ { test: /\.(woff2?|svg)$/, loader: 'url-loader?limit=10000' }, { test: /\.(ttf|eot)$/, loader: 'file-loader' }, ], }, ``` 再次运行 npm run dev,发现下面的页面效果。 ![](/uploads/images/20230703/2f7d17244761ac625e1371067db94bce.png) 字体图标和 css 都没问题了,但是 js 没加载好,点击按钮没有弹出模态框。 查看报错: ![](/uploads/images/20230703/22f5447aae86bdf30083eba53d137526.png) 原来是 jquery 没加载到。 在 webpack.config.js 配置文件的 loader 部分加上下面这行: ``` { test:/bootstrap-sass[\/\\]assets[\/\\]javascripts[\/\\]/, loader: 'imports-loader?jQuery=jquery' }, ``` 然后在终端上执行下面的命令: ``` $ npm install --save-dev imports-loader jquery ``` 即可解决问题。 效果: ![](/uploads/images/20230703/6a4f484f3387f9e30fe142564815c853.png) 点击按钮后,模态框弹出来了,good! ### 优化目录结构 我们运行一下 npm run prod 命令,没啥问题,目录结构是下面这样的: ``` dist ├── 448c34a56d699c29117adc64c43affeb.woff2 ├── 89889688147bd7575d6327160d64e760.svg ├── app.bundle.f3ffd242134090bbd4b7.js ├── b86262bb1045a2b16a4d9fcf64afc1b1.svg ├── bootstrap.f3ffd242134090bbd4b7.js ├── contact.f3ffd242134090bbd4b7.js ├── contact.html ├── e18bbf611f2a2e43afc071aa2f4e1512.ttf ├── f4769f9bdb7466be65088239c12046d1.eot ├── fa2772327f55d8198301fdb8bcfc8158.woff ├── images │ ├── glyphicons-halflings-regular.svg │ └── money-bag.svg ├── index.html └── style.css ``` 比较乱,如果能把 css,js,字体文件分开成各个目录就蛮好的。 我们来改一下配置: webpack.config.js ``` // css 文件放到 css 目录中 new ExtractTextPlugin({ filename: '[name].css', disable: !isProd, publicPath: 'css/' }), // 字体文件都放到 fonts 目录中 { test: /\.(woff2?|svg)$/, loader: 'url-loader?limit=10000&name=[name].[ext]&outputPath=fonts/' }, { test: /\.(ttf|eot)$/, loader: 'file-loader?name=[name].[ext]&outputPath=fonts/' }, ``` 运行 npm run prod 之后,dist 的目录结构如下: ``` dist ├── app.bundle.0cc9d9267f555d83ccb0.js ├── bootstrap.0cc9d9267f555d83ccb0.js ├── contact.0cc9d9267f555d83ccb0.js ├── contact.html ├── css │ ├── app.bundle.css │ └── bootstrap.css ├── fonts │ ├── glyphicons-halflings-regular.eot │ ├── glyphicons-halflings-regular.svg │ ├── glyphicons-halflings-regular.ttf │ ├── glyphicons-halflings-regular.woff │ ├── glyphicons-halflings-regular.woff2 │ └── money-bag.svg ├── images │ ├── glyphicons-halflings-regular.svg │ └── money-bag.svg └── index.html ``` 这样目录结构就比刚才清晰多了。
上一篇:
webpack打包图片
下一篇:
ProvidePlugin 插件处理第三方包
该分类下的相关小册推荐:
Webpack实战:入门、进阶与调优(下)
webpack指南
Webpack实战:入门、进阶与调优(中)
Webpack实战:入门、进阶与调优(上)
全解webpack前端开发环境定制