Webpack 是一个前端资源的打包工具,它可以将js、image、css等资源当成一个模块进行打包。
中文官方网站:https://www.webpackjs.com/
Webpack安装教程 - 图5

官网给出的解释:
本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler)。当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个 bundle。

打包的好处

  • 将许多碎小文件打包成一个整体,减少单页面内的衍生请求次数,提高网站效率。
  • 将ES6的高级语法进行转换编译,以兼容老版本的浏览器。
  • 将代码打包的同时进行混淆,提高代码的安全性。

1、安装


webpack支持全局安装和本地安装,官方推荐是本地安装
输入命令:npm install webpack --save-dev
webpack 4+ 版本,还需要安装 CLI ,输入命令:npm install webpack webpack-cli --save-dev
我们注意下项目中文件夹下package.json文件,打开文件,可以看到我们之前用npm安装过的文件都会出现在这里:

  1. // 运行时依赖,使用npm --save命令安装会出现在这里,会随项目打包
  2. "dependencies": {
  3. "npm": "^6.9.0",
  4. "vue": "^2.6.10",
  5. "vue-router": "^3.0.3"
  6. },
  7. // 开发时依赖,一般是开发的工具,使用npm --dev命令安装会出现在这里,不随项目一起打包
  8. "devDependencies": {
  9. "webpack": "^4.29.6",
  10. "webpack-cli": "^3.3.0"
  11. }

2、核心概念


学习Webpack,需要先理解四个核心概念:

  • 入口(entry)
    webpack打包的起点,可以有一个或多个,一般是js文件。webpack会从起点文件开始,寻找起点直接或间接依赖的其它所有的依赖,包括JS、CSS、图片资源等,作为将来打包的原始数据
  • 输出(output)
    出口一般包含两个属性:path和filename。用来告诉webpack打包的目标文件夹,以及文件的名称。目的地也可以有多个。
  • 加载器(loader)
    webpack本身只识别Js文件,如果要加载非JS文件,必须指定一些额外的加载器(loader),例如css-loader。然后将这些文件转为webpack能处理的有效模块,最后利用webpack的打包能力去处理。
  • 插件(plugins)
    插件可以扩展webpack的功能,让webpack不仅仅是完成打包,甚至各种更复杂的功能,或者是对打包功能进行优化、压缩,提高效率。

3、编写webpack配置


编写一个webpack的配置,来指定一些打包的配置项。配置文件的名称,默认就webpack.config.js,放到hello-vue的根目录,配置文件中就是要指定上面说的四个核心概念,入口、出口、加载器、插件。不过,加载器和插件是可选的。我们先编写入口和出口

① 入口


webpack打包的起点,可以有一个或多个,一般是js文件。我们所有的东西都集中在index.html,不是一个js,那怎么办?
答案是新建一个js,把index.html中的部分内容进行集中,然后在index.html中引用这个js
然后把原来index.html中的js代码全部移动到index.js中

  1. // 使用es6的语法导入js模块
  2. import Vue from '../node_modules/vue/dist/vue';
  3. import VueRouter from '../node_modules/vue-router/dist/vue-router';
  4. import loginForm from './user/login';
  5. import registerForm from './user/register';
  6. Vue.use(VueRouter);// install的组件需要use
  7. // 创建vue对象
  8. const router = new VueRouter({
  9. routes: [ // 编写路由规则
  10. // path: 路由请求路径;component:组件名称
  11. {path: "/login", component: loginForm},
  12. {path: "/register", component: registerForm}
  13. ]
  14. });
  15. var vm = new Vue({
  16. el: "#app",
  17. components: {
  18. loginForm,
  19. registerForm
  20. },
  21. router
  22. });

原来的index.html中引入了很多其它js,在这里我们使用es6的import语法进行导入。
注意,要使用import,就需要在login.js和register.js中添加export导出语句:

  1. const loginForm={
  2. template: '\
  3. <div>\
  4. <h2>登陆页</h2>\
  5. 用户名:<input type="text"><br>\
  6. 密&emsp;码:<input type="password">\
  7. </div>',
  8. }
  9. export default loginForm;
  1. const registerForm = {
  2. template:'\
  3. <div>\
  4. <h2>注册页</h2> \
  5. 用&ensp;户&ensp;名:<input type="text"><br/>\
  6. 密&emsp;&emsp;码:<input type="password"><br/>\
  7. 确认密码:<input type="password"><br/>\
  8. </div>\
  9. '
  10. }
  11. export default registerForm;

vue-router使用模块化加载后,必须增加一句:Vue.use(VueRouter)
这样,index.js就成了我们整个配置的入口了。
在webpack.config.js中添加以下内容:

  1. module.exports={
  2. entry:'./src/index.js', //指定打包的入口文件
  3. }

② 出口


出口,就是输出的目的地。一般我们会用一个dist目录,作为打包输出的文件夹:
Webpack安装教程 - 图6

然后,编写webpack.config.js,添加出口配置:

  1. module.exports={
  2. entry:'./src/main.js', //指定打包的入口文件
  3. output:{
  4. // path: 输出的目录,__dirname是相对于webpack.config.js配置文件的绝对路径
  5. path : __dirname+'/dist',
  6. filename:'build.js' //输出的js文件名
  7. }
  8. }

4、执行打包


在控制台输入以下命令:npx webpack --config webpack.config.js
随后,查看dist目录下会出现一个build.js文件,尝试打开,你根本看不懂:所有的js合并为1个,并且对变量名进行了随机打乱,这样就起到了 压缩、混淆的作用。

5、测试运行


在index.html中引入刚刚生成的build.js文件:效果跟之前写在里面的一样

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. </head>
  7. <body>
  8. <div id="app">
  9. <!--router-link来指定跳转的路径-->
  10. <span><router-link to="/login">登录</router-link></span>
  11. <span><router-link to="/register">注册</router-link></span>
  12. <hr/>
  13. <div>
  14. <!--vue-router的锚点-->
  15. <router-view></router-view>
  16. </div>
  17. </div>
  18. <script src="../dist/build.js"></script>
  19. </body>
  20. </html>

6、打包CSS


编写一段CSS代码,对index的样式做一些美化:
Webpack安装教程 - 图7

main.css

  1. #app a{
  2. display: inline-block;
  3. width: 150px;
  4. line-height: 30px;
  5. background-color: dodgerblue;
  6. color: white;
  7. font-size: 16px;
  8. text-decoration: none;
  9. }
  10. #app a:hover{
  11. background-color: whitesmoke;
  12. color: dodgerblue;
  13. }
  14. #app div{
  15. width: 300px;
  16. height: 150px;
  17. }
  18. #app{
  19. width: 305px;
  20. border: 1px solid dodgerblue;
  21. }

① 安装加载器


webpack默认只支持js加载。要加载CSS文件,必须安装加载器:命令:npm install style-loader css-loader --save-dev

  1. "devDependencies": {
  2. "css-loader": "^2.1.1",
  3. "style-loader": "^0.23.1",
  4. "webpack": "^4.29.6",
  5. "webpack-cli": "^3.3.0"
  6. }

② index.js引入css文件

  1. import './css/main.css'

③ 配置加载器


在webpack.config.js配置文件中配置css的加载器

  1. module.exports = {
  2. entry: './src/main.js', //指定打包的入口文件
  3. output: {
  4. path: __dirname + '/dist', // 注意:__dirname表示webpack.config.js所在目录的绝对路径
  5. filename: 'build.js' //输出文件
  6. },
  7. module: {
  8. rules: [
  9. {
  10. test: /\.css$/, // 通过正则表达式匹配所有以.css后缀的文件
  11. use: [ // 要使用的加载器,这两个顺序一定不要乱
  12. 'style-loader',
  13. 'css-loader'
  14. ]
  15. }
  16. ]
  17. }
  18. }

④ 重新打包


输入打包指令:npx webpack --config webpack.config.js
效果图:
Webpack安装教程 - 图8

7、script脚本


我们每次使用npm安装,都会在package.json中留下痕迹,事实上,package.json中不仅可以记录安装的内容,还可编写脚本,让我们运行命令更加快捷。
我们可以把webpack的命令编入其中:
Webpack安装教程 - 图9

以后,如果要打包,就可以直接输入:npm run build即可。
npm run :执行npm脚本,后面跟的是配置脚本的名称build

8、打包HTML


之前的打包过程中,除了HTML文件外的其它文件都被打包了,当在线上部署时,我们还得自己复制HTML到dist,然后手动添加生成的js到HTML中,这非常不友好。
webpack中的一个插件:html-webpack-plugin,可以解决这个问题。

① 安装插件:npm install html-webpack-plugin --save-dev


需要在webpack.config.js中添加插件:

  1. const HtmlWebpackPlugin = require('html-webpack-plugin');
  2. module.exports = {
  3. entry: './src/main.js', //指定打包的入口文件
  4. output: {
  5. path: __dirname + '/dist', // 注意:__dirname表示webpack.config.js所在目录的绝对路径
  6. filename: 'build.js' //输出文件
  7. },
  8. module: {
  9. rules: [
  10. {
  11. test: /\.css$/, // 通过正则表达式匹配所有以.css后缀的文件
  12. use: [ // 要使用的加载器,这两个顺序一定不要乱
  13. 'style-loader',
  14. 'css-loader'
  15. ]
  16. }
  17. ]
  18. },
  19. plugins:[
  20. new HtmlWebpackPlugin({
  21. title: '首页', //生成的页面标题<head><title>首页</title></head>
  22. filename: 'index.html', // dist目录下生成的文件名
  23. template: './src/index.html' // 我们原来的index.html,作为模板
  24. })
  25. ]
  26. }

② 将原来HTML中的引入js代码删除:

③ 再次打包:npm run build

④ 查看dist目录:
Webpack安装教程 - 图10

打开index.html,发现已经自动添加了当前目录下的build.js

9、热更新的web服务


刚才的案例中,每次修改任何js或css内容,都必须重新打包,非常麻烦。
webpack给我们提供了一个插件,可以帮我们运行一个web服务,加载页面内容,并且修改js后不需要重新加载就能看到最新结果:


① 安装插件:npm install webpack-dev-server --save-dev

② 添加启动脚本:在package.json中配置script

  1. "scripts": {
  2. "dev": "webpack-dev-server --inline --hot --open --port 8080 --host 127.0.0.1"
  3. },
  • inline:自动刷新
  • hot:热加载
  • port:指定端口
  • open:自动在默认浏览器打开
  • host:可以指定服务器的 ip,不指定则为127.0.0.1

③ 运行脚本:npm run dev

在开发中,需要打包的东西不止是js、css、html。还有更多的东西要处理,这些插件和加载器如果我们一一去添加就会比较麻烦。
vue官方提供了一个快速搭建vue项目的脚手架:vue-cli,使用它能快速的构建一个web工程模板。
官网:https://github.com/vuejs/vue-cli
安装命令:npm install -g vue-cli

1、快速上手

新建一个module:

Webpack安装教程 - 图11

切换到该目录:
Webpack安装教程 - 图12

用vue-cli命令,快速搭建一个webpack的项目:vue init webpack
看着安装即可,最后显示这个安装成功,可以使用npm run dev命令启动
Webpack安装教程 - 图13

2、项目结构
Webpack安装教程 - 图14

入口文件:main.js
Webpack安装教程 - 图15

3、单文件组件

我们看到有一类后缀名为.vue的文件,我们称为单文件组件
Webpack安装教程 - 图16

每一个.vue文件,就是一个独立的vue组件。类似于我们刚才写的login.js和register.js
只不过,我们在js中编写 html模板和样式非常的不友好,而且没有语法提示和高亮。

而单文件组件中包含三部分内容:

  • template:模板,支持html语法高亮和提示
  • script:js脚本,这里编写的就是vue的组件对象,还可以有data(){}等
  • style:样式,支持CSS语法高亮和提示

每个组件都有自己独立的html、JS、CSS,互不干扰,真正做到可独立复用。

4、运行 看看生成的package.json:
Webpack安装教程 - 图17

  • 可以看到这引入了非常多的依赖,绝大多数都是开发期依赖,比如大量的加载器。
  • 运行时依赖只有vue和vue-router
  • 脚本有三个:

    • dev:使用了webpack-dev-server命令,开发时热部署使用
    • start:使用了npm run dev命令,与上面的dev效果完全一样,当脚本名为“start”时,可以省略“run”。
    • build:等同于webpack的打包功能,会打包到dist目录下。


    我们执行npm run dev 或者 npm start 都可以启动项目:
    Webpack安装教程 - 图18

转载自CSDN,原文链接:webpack和vue-cli