抛弃console.log(),拥抱浏览器Debugger

译者按: 切换成本真的不高,建议使用开发者工具来Debug!html

为了保证可读性,本文采用意译而非直译。另外,本文版权归原做者全部,翻译仅用于学习。linux

在我成为一名开发者路上也掉进过一些坑,对于新手来讲一个最大的挑战就是debug。刚开始,我一度认为在控制台下使用console.log()打印变量是最棒的方法。而实际上,这样作是至关低效的。我不怕大家嘲笑我,给大家分享一下我曾经是这么干的:chrome

console.log(‘Total Price:’, total) // 查看total的值

console.log(‘Here’) // 打印Here来确认程序执行到这个地方

我想大多数开发者会意识到这不是你应该用来debug的方法,应该有更好的方案! 幸运的是,浏览器的Debug工具很好用!在本文我会介绍谷歌开发者工具。小程序

为了更好地跟随我理解这篇文章的内容,我建议你代开个人示例代码跟着走。地址: 点击这里微信小程序

第一步:复现BUG

咱们经过执行一系列的操做来复现bug:浏览器

  1. 一个代码有bug的计算器,若是你尚未打开,点击这里
  2. 在Entree 1输入12;
  3. 在Entree 2输入8;
  4. 在Entree 3输入10;
  5. 在Tax输入10;
  6. Tip选择20%;
  7. 点击Calculate Bill。正确的结果应该是39.6,可是计算器的结果倒是14105.09!

第二步:学习使用Source面板

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

当你点击开发者面板最上面的source标签,开发者面板会呈现三分的效果,分别是:文件导航器、源代码编辑器以及最右侧的Debug面板。app

第三步:设置第一个断点

在咱们设置断点以前,我来给你演示若是使用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/

相关文章
相关标签/搜索