【前端知识点总结】webpack 浅解(二)

webpack

1 . 什么是 webpack

  • webpack 是一个 javascript 的静态模块打包工具
  • webpack 里一切文件皆模块,通过 loader 转换文件类型,通过 plugin 将打包后的文件注入对应阶段的生命周期钩子
  • 最后输出由多个模块组合成的文件,构建模块化项目

2 . webpack 的优点

  • 专注于处理模块化的项目,能做到开箱即用,一步到位
  • 通过plugin扩展,完整好用又不失灵活
  • 通过loaders扩展, 可以让webpack把所有类型的文件都解析打包
  • 社区庞大活跃,经常引入紧跟时代发展的新特性,能为大多数场景找到已有的开源扩展

3 . webpack 加载器和插件的作用

webpack 作用 : 在 node 环境下,对任何文件进行模块化, 分析, 压缩, 打包

加载器的作用 : 让 webpack 识别除 js 文件外的功能类型文件

插件的作用 : 提高 webpack 的使用性,让 webpack 功能性更全面

4 . babel-loader 插件的作用

babel-loader 插件是js语法编译器

可以把你的高版本 js 代码, 转换成低版本的 js 代码

5 . webpack的构建流程

webpack 的运行流程是一个串行的过程,从启动到结束会依次执行以下流程:

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

在以上过程中,webpack 会在特定的时间点广播出特定的事件,插件在监听到感兴趣的事件后会执行特定的逻辑,并且插件可以调用 webpack 提供的 API 改变 webpack 的运行结果

6 . webpack 的热更新原理

webpack 的热更新又称热替换(Hot Module Replacement),缩写为 HMR。这个机制可以做到不用刷新浏览器而将新变更的模块替换掉旧的模块。

HMR的核心就是客户端从服务端拉去更新后的文件,准确的说是 chunk diff (chunk 需要更新的部分),实际上 WDS(webpack-dev-server) 与浏览器之间维护了一个 Websocket,当本地资源发生变化时,WDS 会向浏览器推送更新,并带上构建时的 hash,让客户端与上一次资源进行对比。客户端对比出差异后会向 WDS 发请求来获取更改内容(文件列表、hash),这样客户端就可以再借助这些信息继续向 WDS 发起 jsonp 请求获取该chunk的增量更新。

后续的部分(拿到增量更新之后如何处理?哪些状态该保留?哪些又需要更新?)由 HotModulePlugin 来完成,提供了相关 API 以供开发者针对自身场景进行处理,像react-hot-loader 和 vue-loader 都是借助这些 API 实现 HMR。

webpack-dev-server : 使用webpack-dev-server启动的服务器, 只打包更新的代码, 还提供地址让浏览器访问打包后代码

7 . webpack与grunt、gulp的区别

三者之间的区别

三者都是前端构建工具,grunt和gulp在早期比较流行,现在webpack相对来说比较主流,不过一些轻量化的任务还是会用gulp来处理,比如单独打包CSS文件等。

grunt和gulp是基于任务和流(Task、Stream)的。类似jQuery,找到一个(或一类)文件,对其做一系列链式操作,更新流上的数据, 整条链式操作构成了一个任务,多个任务就构成了整个web的构建流程。

webpack是基于入口的。webpack会自动地递归解析入口所需要加载的所有资源文件,然后用不同的Loader来处理不同的文件,用Plugin来扩展webpack功能。

从构建思路来说

gulp和grunt需要开发者将整个前端构建过程拆分成多个Task,并合理控制所有Task的调用关系 webpack需要开发者找到入口,并需要清楚对于不同的资源应该使用什么Loader做何种解析和加工

对于知识背景来说

gulp更像后端开发者的思路,需要对于整个流程了如指掌 webpack更倾向于前端开发者的思路

8 . webpack 常见的 Loader

1、file-loader : 把文件输出到一个文件夹中,在代码中通过相对 URL 去引用输出的文件

2、 url-loader : 和 file-loader 类似,但是能在文件很小的情况下以 base64 的方式把文件内容注入到代码中去

3、 source-map-loader : 加载额外的 Source Map 文件,以方便断点调试

4、 image-loader : 加载并且压缩图片文件

5、 babel-loader : 把 ES6 转换成 ES5

6、 css-loader : 加载 CSS,支持模块化、压缩、文件导入等特性

7、 style-loader : 把 CSS 代码注入到 JavaScript 中,通过 DOM 操作去加载 CSS。

8、 eslint-loader : 通过 ESLint 检查 JavaScript 代码

8 . Loader和Plugin的区别

作用不同

loader直译为"加载器" : webpack将一切文件视为模块,但是webpack原生是只能解析js文件,如果想将其他文件也打包的话,就会用到loader。 所以loader的作用是让webpack拥有了加载和解析非JavaScript文件的能力。

Plugin直译为"插件" : Plugin可以扩展webpack的功能,让webpack具有更多的灵活性。 在 webpack 运行的生命周期中会广播出许多事件,Plugin 可以监听这些事件,在合适的时机通过 webpack 提供的 API 改变输出结果。

用法不同

Loader : 在module.rules中配置,也就是说他作为模块的解析规则而存在。 类型为数组,每一项都是一个Object,里面描述了对于什么类型的文件(test),使用什么加载(loader)和使用的参数(options)

Plugin : 在plugins中单独配置。 类型为数组,每一项是一个plugin的实例,参数都通过构造函数传入。

猜你喜欢

转载自blog.csdn.net/jiang_ziY/article/details/123660293