webpack配置_webpack的devtool 配置

webpack配置_webpack的devtool 配置_第1张图片

devtool 配置 与 代码调试有关,此配置是为了增强代码调试过程。

前端发展到现阶段,很多时候都不会直接运行源代码,可能需要对源代码进行合并、压缩、转换等操作,真正运行的是转换后的代码。

如下图:

webpack配置_webpack的devtool 配置_第2张图片

这就给调试带来了困难,因为当运行发生错误的时候,我们更加希望能看到源代码中的错误,而不是转换后代码的错误。

为了解决这一问题,chrome浏览器率先支持了source map,其他浏览器纷纷效仿,目前,几乎所有新版浏览器都支持了source map

source map实际上是一个配置,配置中不仅记录了所有源码内容,还记录了和转换后的代码的对应关系。

下图是浏览器处理source map的原理:

webpack配置_webpack的devtool 配置_第3张图片

webpack配置_webpack的devtool 配置_第4张图片

**最佳实践**

1. source map 应在开发环境中使用,作为一种调试手段。

2. source map 不应该在生产环境中使用,source map的文件一般较大,不仅会导致额外的网络传输,还容易暴露原始代码。即便要在生产环境中使用source map,用于调试真实的代码运行问题,也要做出一些处理规避网络传输和代码暴露的问题。

webpack中的source map:

使用 webpack 编译后的代码难以调试,可以通过 devtool 配置来**优化调试体验**。

devtool 的其它配置

官方网站:https://www.webpackjs.com/configuration/devtool/

1、开发环境的配置:

  • eval:

每个模块都使用eval()执行,并且都有//@ sourceURL。此选项会非常快地构建。主要缺点是,由于会映射到转换后的代码,而不是映射到原始代码(没有从 loader 中获取 source map),所以不能正确的显示行数。

  • eval-source-map:

每个模块使用eval()执行,并且 source map 转换为 DataUrl 后添加到eval()中。初始化 source map 时比较慢,但是会在重新构建时提供比较快的速度,并且生成实际的文件。行数能够正确映射,因为会映射到原始代码中。它会生成用于开发环境的最佳品质的 source map。

  • cheap-eval-source-map:

类似eval-source-map,每个模块使用eval()执行。这是 "cheap(低开销)" 的 source map,因为它没有生成列映射(column mapping),只是映射行数。它会忽略源自 loader 的 source map,并且仅显示转译后的代码,就像evaldevtool。

  • cheap-module-eval-source-map:

类似cheap-eval-source-map,并且,在这种情况下,源自 loader 的 source map 会得到更好的处理结果。然而,loader source map 会被简化为每行一个映射(mapping)。

2、生产环境的配置:

  • none:

(省略devtool选项)不生成 source map。这是一个不错的选择。

  • source-map:

整个 source map 作为一个单独的文件生成。它为 bundle 添加了一个引用注释,以便开发工具知道在哪里可以找到它。

  • hidden-source-map:

source-map相同,但不会为 bundle 添加引用注释。如果你只想 source map 映射那些源自错误报告的错误堆栈跟踪信息,但不想为浏览器开发工具暴露你的 source map,这个选项会很有用。

  • nosources-source-map:

创建的 source map 不包含sourcesContent(源代码内容)。它可以用来映射客户端上的堆栈跟踪,而无须暴露所有的源代码。你可以将 source map 文件部署到 web 服务器。

你可能感兴趣的:(webpack配置)