首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
webpack介绍
安装webpack
webpack实现hello world
webpack配置文件
webpack 插件
使用 loader 处理 CSS 和 Sass
webpack-dev-server
webpack配置 react 开发环境
clean-webpack-plugin插件
webpack配置多个 HTML 文件
使用 pug (jade) 作为 HTML模板
热替换 HMR 处理 CSS
生产环境 vs 开发环境
webpack打包图片
webpack打包Bootstrap
ProvidePlugin 插件处理第三方包
理解devtool: 'source-map'
生产环境与开发环境配置文件分离
当前位置:
首页>>
技术小册>>
Webpack零基础入门
小册名称:Webpack零基础入门
正如标题所说,有时候,你在看别人的 webpack.config.js 文件的配置的时候,你会发现他们可能加了这么一行: ``` devtool: 'source-map' ``` 从字面上来想象,devtool 好像跟开发有关,source-map 好像跟 源码 或 地图 有关,与其去猜,我们不如通过实例来感受下它真正的意思。 我们这节只是入门教程的其中一篇,不从太深入地角度来理解 source-map 的含义,因为它太复杂了,引用一位大牛的话是这么说的,看下面的图片: ![](/uploads/images/20230703/312f5ffd761eafc2c61c568851869232.png) 下面我们开始来感受下 source-map 的魔力。 ### 先不使用 source-map 的情况 我们先在 js 里随便写一些错误的代码,也就是说你可以乱写一些不存在的方法。 比如下面这样: src/app.js ``` import css from './app.scss'; ... // 这个 sss 方法不存在,是我随便写的 sss import $ from 'jquery'; import './jquery.changeStyle'; ... ``` 写错代码很正常啊,关键是要懂得如何调试,就是要先找到哪出错,把它改过来就好。 我们来找一下哪里出错了。 打开浏览器的开发者工具,如下: ![](/uploads/images/20230703/0d27034e8182a7ccecc5484daa0da220.png) 接着打开上图中的那个链接,然后: ![](/uploads/images/20230703/86131282b76e0bf92cc5a99fc0ba1580.png) 这样会一脸懵懂的,因为仅仅定位到编译后的 app.bundle.js 文件是没用的,因为还是找不到源文件,那也就无法改正错误的代码。 ### 使用 devtool: 'source-map' 那怎么办呢?很简单。 在 webpack.config.js 文件中添加 devtool: 'source-map',如下所示: ``` module.exports = { entry: { ... }, devtool: 'source-map' } ``` 这样再来试一下刚才的调试操作。 ![](/uploads/images/20230703/7ddbc9aa9797f1d659913bdba965df9a.png) 接着看下面的图片: ![](/uploads/images/20230703/9cdf948045c8da6895ee7b851ef3c100.png) 我们已经解决了问题,这样就能够查看哪里报错并找到报错的源文件。 刚才我们处理的是 javascript 文件,那 css 文件呢? 我们来看下。 ### 处理 css 文件 首先,我们还是先来写一些错的 css 代码。 src/app.scss ``` body { background: pink; p { /* xxxx 是故意写错的。 */ color: xxxx; } } ``` 我的 html 页面是有 p 标签的,我们用开发者工具定位到 p 标签的样式中,如下图所示: ![](/uploads/images/20230703/6c636299de141fd4bc3f6a496c9530c3.png) 从图中可以看出,我们无法调试 css 代码,即使用了 devtool: 'source-map' 也没用。 那怎么办呢? 之前我们是使用下面一些 loader 来处理 css 的。(不懂的,可以查看以前的章节) ``` var cssDev = ['style-loader', 'css-loader', 'sass-loader']; ``` 这几个 loader 刚好都有个选项叫 sourceMap。(这个可以分别查看他们的官网得知) 我们把它设为 true 即可。 我们把上面的代码改成下面这样: ``` var cssDev = ['style-loader', 'css-loader?sourceMap', 'sass-loader?sourceMap']; ``` 我们再来试试效果。 ![](/uploads/images/20230703/062a704cbf39e9ad1c9405eddc297443.png) 接着,我们点进去之后,得到类似下图所示的情况。 ![](/uploads/images/20230703/3717a8ce311f3cb88fa0e432535e9a14.png) 那这样,我们就可以方便地调试 javascript 和 css 代码了。
上一篇:
ProvidePlugin 插件处理第三方包
下一篇:
生产环境与开发环境配置文件分离
该分类下的相关小册推荐:
webpack指南
Webpack实战:入门、进阶与调优(上)
Webpack实战:入门、进阶与调优(中)
全解webpack前端开发环境定制
Webpack实战:入门、进阶与调优(下)