抛弃console.log(),拥抱浏览器Debugger
译者按: 切换成本真的不高,建议使用开发者工具来Debug!
为了保证可读性,本文采用意译而非直译。另外,本文版权归原作者所有,翻译仅用于学习。
在我成为一名开发者路上也掉进过一些坑,对于新手来说一个最大的挑战就是debug。刚开始,我一度认为在控制台下使用console.log()打印变量是最棒的方法。而实际上,这样做是相当低效的。我不怕你们嘲笑我,给你们分享一下我曾经是这么干的:
console.log(‘Total Price:’, total) // 查看total的值
console.log(‘Here’) // 打印Here来确认程序执行到这个地方
我想大多数开发者会意识到这不是你应该用来debug的方法,应该有更好的方案!
幸运的是,浏览器的Debug工具很好用!在本文我会介绍谷歌开发者工具。
为了更好地跟随我理解这篇文章的内容,我建议你代开我的示例代码跟着走。地址: 点击这里
第一步:复现BUG
我们通过执行一系列的操作来复现bug:
- 一个代码有bug的计算器,如果你还没有打开,点击这里;
- 在Entree 1输入12;
- 在Entree 2输入8;
- 在Entree 3输入10;
- 在Tax输入10;
- Tip选择20%;
- 点击
Calculate Bill。正确的结果应该是39.6,但是计算器的结果却是14105.09!

第二步:学习使用Source面板
你需要学会熟练使用开发者工具,你可以使用快捷键Command+Option+I (Mac) 或则 Control+Shift+I (Linux)来打开。(或则右键,选择检查选项,就会弹出开发者面板)

当你点击开发者面板最上面的source标签,开发者面板会呈现三分的效果,分别是:文件导航器、源代码编辑器以及最右侧的Debug面板。
第三步:设置第一个断点
在我们设置断点之前,我来给你演示如果使用console.log()是什么效果:

如果你使用开发者工具,就不用写一堆的console.log()了。我们可以设置断点,通过单步调试来查看变量的值。
断点就是一个你在代码中添加标记,用来告诉浏览器执行到这个位置暂停。
我们将会在整个程序的最开始设置一个断点。
在最右侧的Debugger面板,点击"Event Listener Breakpoints",展开"Mouse",然后选中'click'。
现在如果我们点击Calculate Bill按钮,程序会停在第一个函数"onClick()"。如果没有执行到这里,那么点击播放按钮,总会跳到index的第6行。
第四步:单步调试
在整个Debug的过程中,有两种执行的方式:”step into"和“step over"。
“step into"会进入当前遇到的每一个函数内部,然后一行一行执行;
“step over”则会跳过函数内部的细节,直接执行整个函数。
下面是一个展示例子,在右侧的Scope下,所有局部变量的值都显示出来了。

第五步:在某行设置断点
可以单步调试代码是不是很棒?不过一步一步往下执行有点繁琐。通常,我只想知道在某个位置变量的值,而不是要一步一步执行过去。我们可以在某一行去设置断点。
作者备注:能够在代码任意行设置断点查看变量值是我停止使用console.log的主要原因。
在文件的左侧,显示文件行数的位置点击即可设置断点。
注意:如果你发现无法操作,请先清除掉之前选中的click选项。

你可以看到,右侧显示subtotal的值为10182,并且在代码旁边也显示了变量的值。
我想已经知道BUG的原因了:字符串拼接?
第六步:添加观察表达式
这个通常用来观察变量的值在程序的执行过程中的变化,点击右侧的"watch"选项将其展开,你可以输入变量名或者表达式。
为了演示起见,我们观察"entree 1"和"typeof entree1"。

通过查看entree1的类型,发现并不是数字而是字符串。那么问题就出在如何获取这个值的。也许,querySelector()是问题的关键。
第七步:修复代码
通过进一步检查,确定querySelector()就是问题所在。

如何修复呢?我们可以使用Number函数将字符串转换为数字,比如Number(getEntree1())。
为了编辑代码,你需要到“Elements"选项,它在”Sources"的左侧。如果你没有看到JavaScript代码,你需要展开script标签。 然后右键点击选择“edit as html"。

如果你建立了一个workspace,那么代码会直接保存。不然,可以使用command+s (mac) 或则 control+s (linux)保存一份本地拷贝。
接下来,我们再来试一试看看效果。

关于Fundebug
Fundebug专注于JavaScript、微信小程序、微信小游戏、支付宝小程序、React Native、Node.js和Java实时BUG监控。 自从2016年双十一正式上线,Fundebug累计处理了9亿+错误事件,得到了Google、360、金山软件、百姓网等众多知名用户的认可。欢迎免费试用!

版权声明
转载时请注明作者Fundebug以及本文地址:
https://blog.fundebug.com/2018/12/11/stop-using-console-log/
抛弃console.log(),拥抱浏览器Debugger的更多相关文章
- webpack打包时删除console.log,和debugger
开发过程中我们不可避免的需要console.log调试,然而在上线时如果不删除这些console.log可能会造成内存泄漏,因为console.log出来的变量是不会被GC的,webpack给我们提供 ...
- webpack打包去掉console.log打印与debugger调试
如图,找到build/webpack.prod.conf.js 在 UglifyJsPlugin 插件下添加下列代码 drop_debugger: true, drop_console: true
- 解析浏览器和nodejs环境下console.log()的区别
写在前面的 在开发调试过程中,我们经常需要调用console.log 方法来打印出当前变量的值,然而,console.log在浏览器环境下 有时会出现一些异常的现象 开撸代码 在浏览器和nodejs环 ...
- [技巧篇]13.从今天开始做一个有理想的人,放弃alter的调试,拥抱console.log
在js前端开发时,为了调试经常会加上 console.log.但是在有的浏览器(比如IE)中会报错,怎么办呢?好像10之后也开始支持了!如果以防方一,可以使用如下方式 在js文件最前面添加如下js代码 ...
- 在浏览器控制台输出内容 console.log(string);
在浏览器控制台中写如数据 1添加 <script type="text/javascript">djConfig = { isDebug: true };< ...
- console.log在IE浏览器中会有异常
因为在IE浏览器无此方法,故此重写 方法一: var console = console || { log: function () { return false; } }; 方法二:window.c ...
- IE6789浏览器使用console.log类似的方法输出调试内容但又不影响页面正常运行
问题来源:外网IE下,触发js报错.经检测,未清除console造成.清除console后,解决. 问题原因:console.log 原先是 Firefox 的“专利”,严格说是安装了 Firebug ...
- 浏览器好玩的的 console.log
现在很多网站,你在访问他页面的时候, 你要查看 console 的话, 看到有文章介绍的,一定想知道是怎么展示来的吧 如 baidu 的 你懂的,其实很简单,代码如下, console 输出下就行 c ...
- console.log、toString方法与js判断变量类型
Java调用system.print.out()是会调用toString方法打印js里的console.log也是控制台打印,很多时候,我们以为也是调用toString方法,其实并不是.我们在chro ...
随机推荐
- js怎么实现继承?
3. js怎么实现继承? 1. 使用原型prototype 这个问题其实之前总结过了……但是面试时候有点忘……主要思想是记得的,但是不会写,还是基础太不牢靠,写的太少了.一开始因为不知道怎么能继承父类 ...
- 【CF429E】 Points and Segments(欧拉回路)
传送门 CodeForces 洛谷 Solution 考虑欧拉回路有一个性质. 如果把点抽出来搞成一条直线,路径看成区间覆盖,那么一个点从左往右被覆盖的次数等于从右往左被覆盖的次数. 发现这个性质和本 ...
- Javascript高级编程学习笔记(51)—— DOM2和DOM3(3)操作样式表
操作样式表 在JS中样式表用一种类型来表示,以便我们在JS对其进行操作 这一类型就是CSSStyleSheet 即CSS样式表类型,包括了之前 style 对象所不包括的外部样式表以及嵌入样式表 其中 ...
- 服务器端PHP允许跨域
解决跨域的关键是设置 Access-Control-Allow-Origin. 例如:客户端的域名是 api.itbsl.com,而请求的域名是www.itbsl.com 如果直接使用ajax访问,会 ...
- 小奶狗给小喵咪上CSS课程
小奶狗给小喵咪上CSS课程 小奶狗,你好啊? 小喵咪你好~ 听说学习HTML,要学习CSS是吗? 是的,小甜心~ 那么CSS是什么呢? CSS是Cascading Style Sheet英文的缩写,中 ...
- lua模块demo(redis,http,mysql,cjson,本地缓存)
1. lua模块demo(redis,http,mysql,cjson,本地缓存) 1.1. 配置 在nginx.conf中设置lua_shared_dict my_cache 128m; 开启ngi ...
- GitLab CI .NET 部署中的几个坑
信息乱码 Msbuild编译失败 VS却编译成功 设置环境变量本地有用,但是runner跑起来就失败 powershell公共变量为空 命令执行失败,却集成成功,pass了 1.信息乱码 信息乱码是真 ...
- 使用 SonarQube 来分析 .NET Core 项目代码问题
0.介绍 Sonar 是一款开源的代码分析工具,可能有很多人已经用过,本篇文章主要是讲解如何在 Docker 里面安装 Sonar 并且用其来分析 .Net Core 项目. Sonar 是一个用于代 ...
- C++版 - 剑指offer 面试题63:二叉搜索树的第k个结点(二叉树中序遍历的应用) 题解
面试题 63:二叉搜索树的第k个结点 题目:给定一颗二叉搜索树,请找出其中的第k大的结点.例如, 5 / \ 3 7 /\ /\ 2 4 6 8 (见下面的图1) 中,按结点数值大小顺序第三个结点的值 ...
- Java IO API记录
文件路径: public static final String FILEPATH= File.separator+"Users"+ File.separator+"xu ...