js断点调试心得

作者 : 开心源码 本文共4015个字,预计阅读时间需要11分钟 发布时间: 2022-05-11 共73人阅读

1.断点调试是啥?难不难?

断点调试其实并不是多么复杂的一件事,简单的了解无外呼就是打开浏览器,打开sources找到js文件,在行号上点一下罢了。操作起来似乎很简单,其实很多人纠结的是,是在哪里打断点?(我们先看一个断点截图,以chrome浏览器的断点为例)

js断点调试心得

步骤记住没?

使用chrome浏览器打开页面 → 按f12打开开发者工具 → 打开Sources → 打开你要调试的js代码文件 → 在行号上单击一下,OK!恭喜你的处女断点打上了,哈哈~~

2.断点怎样打才合适?

打断点操作很简单,核心的问题在于,断点怎样打才可以够排查出代码的问题所在呢?下面我继续举个例子方便大家了解,废话不多说,上图:

js断点调试心得

假设我们现在正在实现一个加载更多的功可以,如上图,但是现在加载更多功可以出现了问题,点击以后数据没有加载出来,这时候我们第一时间想到的应该是啥?(换一行写答案,大家能看看自己的第一反应是啥)

我最先想到的是,我点击究竟有没有成功?点击事件里的方法有没有运行?好,要想知道这个问题的答案,我们立马去打个断点试试看,断点打在哪?自己先琢磨一下。

接着上图:

js断点调试心得

各位想到没?没错,既然想知道点击能否成功,我们当然是在代码中的点击事件处增加一个断点,切记不要增加在226行哦,由于被执行的是click方法内的函数,而不是226行的选择器。断点现在已经打上了,而后做什么呢?自己再琢磨琢磨~

继续上图:

js断点调试心得

而后我们当然是回去点击加载更多按钮啦,为什么?额。不点击加载更多按钮,怎样去触发点击事件?不触发点击事件,怎样去执行点击事件里的函数?咆哮状。。不过我相信大家一定不会问这么low的问题~不瞎扯了~

继续正题,上面的图就是点击加载更多按钮后的情况,我们能看到左侧的页面被一个半透明的层给盖住了,页面上方还有一串英文和两个按钮,右侧代码227行被增加上了背景色,出现这个情况,先不论那些按钮英文是啥意思有啥作使用,你从这个图得到了什么信息?继续琢磨琢磨~

假如出现了上图这个情况,说明一点,click事件中的函数被调使用了,进一步说明了点击事件生效。那么我们对于这个问题产生的第一个“犯罪嫌疑人”就被排除了。

补充一下:

假如没有出现上面的情况咋办?那是不是说明点击事件没有生效呢?那是什么导致点击事件没有生效?大家自己思考思考~

可可以导致点击事件没生效的起因很多,比多选择器错误,语法错误,被选择的元素是后生成的等。怎样处理呢?

选择器错误,大家能继续往后看到console部分的内容,我想大家就知道怎样解决了

语法错误,细心排查一下,不熟习的语法能百度比照一下

被选择的元素是后生成的,最简单的解决就是用.on()方法去解决,这个东东带有事件委托解决,介绍能自行百度。

那么接下来”犯罪嫌疑人“的身份锁定在哪里呢?

我们将目光投向事件内部,click事件触发了,那么接下来的问题就是它内部的函数问题了。假如你要问为什么?请给我一块豆腐。。。

打个比如,给你一支笔,让你写字,而后你在纸上写了一个字,发现字没出来,为啥?你说我写了呀,纸上都还有划痕。那是不是可可以笔没有墨水或者者笔尖坏了了?这个例子和点击加载更多一个道理,写字这个动作就是点击操作,而内部函数就是墨水或者者笔尖。明白了不~

接着我们分析下点击事件里面的内容,里面包含三句话,第一句话是变量i自增长,第二句话是给按钮增加一个i标签,第三句话是调使用请求数据的方法。

就通过这三句话的本身作使用,我们能将较大一部分嫌疑放在第三句话,一小部分放在第一句和第二句话上,有人可可以会疑惑,第二句话怎样会有嫌疑呢?他的作使用只不过是增加一个标签,对于数据完全没有影响啊,的确,这句话对于数据没有影响,但是出于严谨考虑,它依然有可可以出错,例如它要是少了一个分号呢?或者者句子内部某个符号错误呢?往往就是这种小问题白费我们很多时间。

好,为了进一步锁定”犯罪嫌疑人“,给大家详情一个工具,也是上图出现两个图标之一,见下图:

js断点调试心得

这个小图标的功可以叫”逐语句执行“或者者叫”逐渐执行“,这是我个人了解的一个叫法,意思就是,每点击它一次,js语句就会往后执行一句,它还有一个快捷键,F10。下图示范一下它被点击以后的效果:

js断点调试心得

我单击了两次这个按钮(或者者用F10快捷键),js代码从227行执行到了229行,所以我管它叫”逐语句执行“或者者”逐渐执行“。这个功可以非常的实使用,大部分的调试都会用到它。

太晚了,明天继续写,好戏还在后头~

——————————————————————分割线————————————————————

OK,接着写!

上面详情到我单击了两次“逐语句执行”按钮,代码从227行运行到229行,大家觉得这意味着啥?是不是说明从语法上来说,前两句是没有问题的,那么是不是也同时意味着前两句就排除嫌疑了呢?我看不然。

大家都知道,加载更多就是一个下一页的功可以,而其中最核心的一个就是传给后端的页码数值,每当我点击加载更多按钮一次,页码的数值就要加1,所以假如下一页的数据没出来,是不是有可可以是由于页码数值也就是[i变量](下面统一称呼i)有问题?那么如何排查页码能否存在问题呢?大家自己先思考思考。

下面教大家两种查看页码数值i]实际输出值的方法,上图:

第一种:

js断点调试心得

操作步骤如下:

1.依然是在227行打上断点 → 2. 点击加载更多按钮 → 3. 单击一次“逐语句执行“按钮,js代码执行到228行 → 4.使用鼠标选中i++(什么叫选中大家里不了解?就是你要复制一个东西,是不是要选中它?对,就是这个选中) → 5. 选中以后,鼠标悬浮在目标上方,你就看到上图的结果。

第二种:

js断点调试心得

这个方法其实和第一种差不多,只不过是在控制台输出i的值,大家只要要按照第一种方法执行到第三步 → 4. 打开和sources同一级栏目的console → 5. 在console下方的输入栏里输入i → 6. 按enter回车键就可。

上面的第二种方法里,提到了console这个东西,我们能称呼它为控制台或者者其余什么都能,这不重要~console的功可以很强大,在调试的过程中,我们往往需要知道某些变量的值究竟输出了什么,或者者我们用选择器[$”.div”)这种]能否选中了我们想要的元素等,都能在控制台打印出来。当然直接使用第一种方法也能。

给大家示范一下在console里打印我们想要选中的元素。上图~

js断点调试心得

在控制台中输入$(this),就可得到选择的元素,没错,正是我们所点击的对象——加载更多按钮元素。

在这里给大家说说我对console这个控制台的了解:这个东东就是一个js解析器,是浏览器本身使用来解析运行js的家伙,只不过浏览器通过console让我们开发者在调试过程中,能控制js的运行以及输出。通过上面的两种方法,大家可可以觉得用起来很简单,但是我要给大家提示一下,或者者说是少量新手比较容易遇到的困惑。

困惑一:在没有打断点的情况下,在console输入i,结果console报错了。

这应该是新手很常见的问题,为什么不打断点我就没有办法在控制台直接输出变量的值呢?个人了解这时候i只是一个局部变量,假如不打上断点,浏览器会把所有的js一律解析完成,console并不可以访问到局部变量,只可以访问到全局变量,所以这时候console会报错i未定义,但是当js打上断点时,console解析到了局部变量i所在的函数内,这时候i是可以够被访问的。

困惑二:为什么我直接在console里输入$(“.xxx”)可以打印出东西来呢?

很简单,console本身就是一个js解析器,$(“.xxx”)就是一个js语句,所以自然console可以够解析这个语句而后输出结果。

详情完“逐语句执行”按钮和console控制台的使用法,最后再详情一个按钮,上图:

js断点调试心得

这个按钮我称呼它为“逐过程执行”按钮,和“逐语句执行”按钮不同,“逐过程执行”按钮常使用在一个方法调使用多个js文件时,涉及到的js代码比较长,则会用到这个按钮。

上图:

js断点调试心得

假设上图我只在227行打了个断点,而后一直点击逐语句执行”按钮到229行,这时候假如再点击一次“逐语句执行”按钮呢?则会进入下图的js里:

js断点调试心得

这些都是zepto库文件的内容,没啥好看的,里面运行很复杂,我们不可可以一直用“逐语句执行”按钮,这样你会发现你按了大半天还在库文件里面绕。。。这时候咋办?那就该“逐过程执行”按钮上场了。

上图:

js断点调试心得

我除了在227行打了一个断点,同时还在237行打了一个断点,当我们运行到229行时,直接单击“逐过程执行”按钮,你会发现,js直接跳过了库文件,运行到了237行,大家能自己用体验一下。

最后总结:

本文主要详情了“逐语句执行”按钮、“逐过程执行”按钮、console控制台这三个工具,以及调试bug时的少量思路。工具的使用法我就不再赘述了,大家知道使用法就行,具体怎样去更正当的用,还需要大家通过大量的实践去总结提升~

我其实在本文主要想讲的是调试bug的一个思路,但是因为选的例子涉及东西太多。。。怕一律写下来内容太长,大家也没兴趣看,所以我就简单的选了一部分给大家讲解,不知道大家有没有收获。别看我调试三句话写了一堆的东西,假如真的在实际项目中你也像我这样去做,预计你调试一个Bug的时间会比写一个脚本的时间还长很多。。。在实际情况下,我们应该养成拿到问题的第一时间,自行在脑海中排查问题,找到最有可可以出现问题的点,假如没办法迅速的排查出最重要的点,那么你能用最麻烦但是很靠谱的方法,利使用“逐语句执行”按钮将整个和问题相关的js依次去执行一遍,在执行的过程中,自己也跟着理清思路,同时注意下每个变量的值以及选择器选中的元素能否正确,一般来说,这样做一遍下来,bug都处理的差不多了。

所以个人认为,我们调试bug的思路应该是这样的:首先,js能否成功的执行进来;其次,js能否存在逻辑问题,变量问题,参数问题等等;最后,假如上述都没有问题,请仔细查看各种符号。

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » js断点调试心得

发表回复