前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >前端模块打包之Webpack

前端模块打包之Webpack

原创
作者头像
全栈开发Dream
修改2021-06-08 13:18:41
6750
修改2021-06-08 13:18:41
举报
文章被收录于专栏:全栈开发Dream

前言

这里总结一下,自己在学习webpack时,比较疑惑的地方

1、什么是webpack?

webpack是前端模块化打包工具,它把一切都看成模块,比如css、js、图片文件等都可以看成模块,再通过一些loader(加载器)和plugin(插件)对资源进行处理,打包成符合生产环境的前端资源。

2、为什么需要webpack?

  • 多模块文件依赖,增加代码复用性

传统引入资源类似这种形式,没有模块化关系。

代码语言:txt
复制
  <body>
  <script type="text/javascript" src="a.js"></script>
  <script type="text/javascript" src="b.js"></script>
  <script type="text/javascript" src="c.js"></script>
  </body>

引入模块化关系

代码语言:txt
复制
  // mathUntil.js

  function sum(num1, num2) {

    return num1 + num2;
}
function mul(num1, num2) {
    return num1 \* num2;
}
export {
    sum,
    mul
}
  // main.js

  // 使用

   const {
    sum,

    mul
} = require("./js/mathUtil.js")

console.log(sum(10, 20));

console.log(mul(2, 4));

还可以使用import

代码语言:txt
复制
// 举个栗子
// a.js
export default function (a, b) {
    return a + b;
}

// index.js
import sum from 'a.js';
// 使用
console.log(sum(1,2))// 3
  • 打包拓展语言

一般情况下CSS的预处理语言Less、Scss,以及ES6+的一些语法(模块化import、export等),浏览器还不能直接运行并显示处理,所以需要webpack打包成符合浏览器识别显示的格式。

  • 提供一些功能强大的loader(加载器)、plugin(插件),减少代码量或者便于项目维护

3、常见的Loade

  • file-loader:把文件输出到一个文件夹中,在代码中通过相对 URL 去引用输出的文件
  • url-loader:和 file-loader 类似,但是能在文件很小的情况下以 base64 的方式把文件内容注入到代码中去
  • source-map-loader:加载额外的 Source Map 文件,以方便断点调试
  • image-loader:加载并且压缩图片文件
  • babel-loader:把 ES6 转换成 ES5
  • css-loader:加载 CSS,支持模块化、压缩、文件导入等特性
  • style-loader:把 CSS 代码注入到 JavaScript 中,通过 DOM 操作去加载 CSS。
  • eslint-loader:通过 ESLint 检查 JavaScript 代码

4、常见的Plugin

  • define-plugin:定义环境变量
  • commons-chunk-plugin:提取公共代码
  • uglifyjs-webpack-plugin:通过UglifyES压缩ES6代码

5、webpack的构建流程

明白webpack的构建流程之前,得先了解一下

entry 入口起点

Chunk 可以理解成多个模块合并成的代码块

  • 初始化参数:从配置文件和 Shell 语句中读取与合并参数,得出最终的参数;
  • 开始编译:用上一步得到的参数初始化 Compiler 对象,加载所有配置的插件,执行对象的 run 方法开始执行编译;
  • 确定入口:根据配置中的 entry 找出所有的入口文件;
  • 编译模块:从入口文件出发,调用所有配置的 Loader 对模块进行翻译,再找出该模块依赖的模块,再递归本步骤直到所有入口依赖的文件都经过了本步骤的处理;
  • 完成模块编译:在经过第4步使用 Loader 翻译完所有模块后,得到了每个模块被翻译后的最终内容以及它们之间的依赖关系;
  • 输出资源:根据入口和模块之间的依赖关系,组装成一个个包含多个模块的 Chunk,再把每个 Chunk 转换成一个单独的文件加入到输出列表,这步是可以修改输出内容的最后机会;
  • 输出完成:在确定好输出内容后,根据配置确定输出的路径和文件名,把文件内容写入到文件系统。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 1、什么是webpack?
  • 2、为什么需要webpack?
  • 3、常见的Loade
  • 4、常见的Plugin
  • 5、webpack的构建流程
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档