Webpack原理笔记

Webpack原理笔记

Webpack是每一个前端工程师都必须掌握的工具,我们掌握工具的前提是熟悉工具。所以了解一些其内部原理能够帮助我们更好的去分析实际业务中遇到的问题。

参考文档

个人梳理

Q1:Webpack构建流程

Q2:Webpack Loader原理

Q3:Webpack Plugin原理

Q4:Loader和Plugin的 区别

一、webpack的打包原理

  1. 识别入口文件
  2. 通过逐层识别模块依赖(Commonjs、amd或者es6的import,webpack都会对其进行分析,来获取代码的依赖)
  3. webpack做的就是分析代码,转换代码,编译代码,输出代码
  4. 最终形成打包后的代码

二、什么是loader

loader是文件加载器,能够加载资源文件,并对这些文件进行一些处理,诸如编译、压缩等,最终一起打包到指定的文件中

  1. 处理一个文件可以使用多个loader,loader的执行顺序和配置中的顺序是相反的,即最后一个loader最先执行,第一个loader最后执行
  2. 第一个执行的loader接收源文件内容作为参数,其它loader接收前一个执行的loader的返回值作为参数,最后执行的loader会返回此模块的JavaScript源码

三、什么是plugin

在webpack运行的生命周期中会广播出许多事件,plugin可以监听这些事件,在合适的时机通过webpack提供的API改变输出结果。

四、loader和plugin的区别

对于loader,它是一个转换器,将A文件进行编译形成B文件,这里操作的是文件,比如将A.scss转换为A.css,单纯的文件转换过程

plugin是一个扩展器,它丰富了webpack本身,针对是loader结束后,webpack打包的整个过程,它并不直接操作文件,而是基于事件机制工作,会监听webpack打包过程中的某些节点,执行广泛的任务

Q5:热更新原理

Q6:DLL

Q7:Tree-Shaking

Q8:Scope Hosting

Q9:异步加载组件

分包策略

Webpack的异步加载原理及分包策略(深度好文,建议收藏) - 云+社区 - 腾讯云