目录
一、了解 Sources 面板
二、设置断点
1. 在代码行设置断点
2. 设置条件断点
3. 在事件监听器上设置断点
4. 在 DOM 节点中设置断点
三、逐步调试
1. 下一步(快捷键:F9)
2. 跳过(快捷键:F10)
3. 进入(快捷键:F11)
4. 跳出(快捷键:Shift+F11)
四、检查范围、调用堆栈和值
1. 范围(Scope)
2. 调用堆栈
3. 值
4. Watch
五、禁用和删除断点
六、使用 VS Code 调试 JavaScript
首页 web前端 js教程 超实用的JavaScript调试技巧

超实用的JavaScript调试技巧

Feb 28, 2022 pm 05:40 PM
javascript

本篇文章给大家带来了关于javascript中的相关知识,其中主要介绍了JavaScript的调试技巧,包括了Sources面板、设置断点等相关问题,希望对大家有帮助。

超实用的JavaScript调试技巧

相关推荐:javascript视频教程

作为前端开发,我们会经常使用 console.log() 来调试程序中的问题。虽然这种方式也能解决一部分问题,但是它的效率不如能执行逐步调试的工具。本文就来学习一下如何使用 Google Chrome developer tools 轻松调试 JavaScript 代码。

多数浏览器都提供了DevTools 供我们调试 JavaScript 应用程序,并且它们的使用方式类似,只要我们学会了如何在一个浏览器上使用调试工具,就很容易在其他浏览器上使用它。

以下就以 Greet Me 程序为例,这个程序非常简单,只需输入名字和愿望,最后会输出一句话:

6cfb7ef8addfe10a894255dae09d85e1.png

当输入两个表单值之后,“愿望”部分没有正确打印,而是打印出了NaN。代码在线调试:https://greet-me-debugging.vercel.app/。接下来,就看看 Chrome DevTools 有什么功能可以调试定位代码的问题。

一、了解 Sources 面板

DevTools 提供了许多不同的工具供我们进行调试,包括 DOM 检查、分析和网络调用检查等。这里要说的是 Sources 面板,它可以帮助我们调试 JavaScript。可以使用快捷键 F12 打开控制面板,并单击 Sources 选项卡以导航到 Sources 面板,也可以直接使用快捷键 Command+Option+I(Mac)或 Control+Shift+I(Windows、Linux)来打开。

ff02b38b563171c004d94ea3a910ad89.png

Sources 面板主要由三个部分组成:

d9be6c7483ae62407b407f2e6433508b.png

  1. 文件导航区:页面请求的所有文件都会在此列出;

  2. 代码编辑区:当我们从文件导航栏中选取一个文件时,该文件的内容就会在此列出,我们可以在这里编辑代码;

  3. Debugger区:这里会有很多工具可以用来设置断点,检查变量值、观察执行步骤等。

如果 DevTools 窗口较宽或未在单独的窗口中打开,则调试器部分将显示在代码编辑器的右侧:

0d3aa9d73683a1bb85776e29f907085c.png

二、设置断点

要开始调试代码,首先要做的就是设置断点,断点就是代码执行暂停以便调试它的逻辑点。

DevTools 允许我们以不同的方式来设置断点:

  • 在代码行;

  • 在条件语句中;

  • 在 DOM 节点处;

  • 在事件侦听器上。

1. 在代码行设置断点

设置代码行断点的步骤:

  • 单击切换到 Sources 选项卡;

  • 从文件导航部分选中需要调试的源文件;

  • 在右侧代码编辑器区域找到需要调试的代码行;

  • 单击行号以在行上设置断点。

0ac505d4e66503aafa2e9ef0a7ddab5d.png

这里就在代码的第 6 行设置了一个断点,代码在执行到这里时就会暂停。

2. 设置条件断点

设置条件断点的步骤:

  • 单击切换到 Sources 选项卡;

  • 从文件导航部分选中需要调试的源文件;

  • 在右侧代码编辑器区域找到需要调试的代码行;

  • 右键单击行号并选择"Add conditional breakpoint"来添加条件断点:

911381fbfb8fb734172dc4f57d63cf91.png

点击之后代码行下方就会出现一个对话框,输入断点的条件即可:

4da62e18f27e13f941885e5a9741bdad.png

按回车键(Enter)即可激活断点,这时就会在打断点行的顶部出现一个橙色的图标:

2d44aa4ba4f4365005d8e6ff2c79eea7.png

当print()方法中的name变量值为Joe时,代码的执行就会暂停。需要注意,只有我们确定调试的代码的大致范围时,才会使用条件断点。

3. 在事件监听器上设置断点

在事件监听器上设置断点的步骤:

  • 单击切换到 Sources 选项卡;

  • 在debugger区域展开Event Listener Breakpoints选项;

  • 从事件列表中选择事件监听器来设置断点。我们的程序中有一个按钮单击事件,这里就选择 Mouse 事件选项中的click。

cd71191d28301dad1804cca9e1382f3f.png

提示:当我们想暂停在事件触发后运行的事件侦听器代码时可以使用此选项。

4. 在 DOM 节点中设置断点

DevTools 在 DOM 检查和调试方面同样很强大。当在 DOM 中添加、删除或者修改某些内容时,可以设置断点来暂停代码的执行。

在 DOM 上设置断点的步骤:

  • 单击切换到 Elements 选项卡;

  • 找到要设置断点的元素;

  • 右键单击元素以获得上下文菜单,选择Break on选项,然后选择Subtree modifications、Attribute modifications、Node removal中的一个即可:

33b6e8da06e4e5054a2039c6c21938d0.png

这三个选项的含义如下:

  • Subtree modifications:当节点内部子节点变化时断点;

  • Attribute modifications:当节点属性发生变化时断点;

  • Node removal:当节点被移除时断点。

如上图,我们在输出消息的 p 的 DOM 发生变化时设置了一个断点。当点击按钮后,问候消息输出到 p 中,子节点的内容发生了变化,就会发生中断。

注意: 当我们怀疑是DOM更改导致了错误时,就可以使用该选项,当 DOM 更改中断时,相关的 JavaScript 代码执行将自动暂停。

三、逐步调试

现在我们知道了设置断点的方式。在复杂的调试情况下,我们可能需要使用这些调试的组合。调试器提供了五个控件来逐步执行代码:

8296f9e426d142096d53816a058e3667.png

下面就分别来看看这些控制都是如何使用的。

1. 下一步(快捷键:F9)

此选项使我们能够在JavaScript代码执行时逐行执行,如果中途有函数调用,单步执行也会进入函数内部,逐行执行,然后退出。

77fb778247ae6f2fc5ccd2ebbae230be.gif

2. 跳过(快捷键:F10)

此选项允许我们在执行代码时跳过一些代码。有时我们可能已经确定某些功能是正常的,不想花时间去检查它们,就可以使用跳过选项。

下面就是单步执行logger()函数时,会跳过函数的执行:

01dbe3fd4831890c1d446d9ee7f071f1.gif

3. 进入(快捷键:F11)

使用该选项可以更深入地了解函数。单步执行函数时,当感觉某个函数的行为异常并想检查它时,就可以使用这个选项来进入函数内部并进行调试。

下面就是单步执行 logger() 函数:

5e72d0662208d5c08bcc294f4205f778.gif

4. 跳出(快捷键:Shift+F11)

在单步执行一个函数时,我们可能不想再继续执行并退出它,就可以使用这些选项退出函数。

下面就是进入了 logger() 函数内部,然后立即退出:

1b69740e19ffe26996591017ea988563.gif

5. 跳转(快捷键:F8)

有时,我们希望从一个断点跳转到另一个断点,而无需在它们之间进行任何调试,就可以使用这个选项来跳转到下一个断点:

e89610269e34c256a7447835afe4021f.gif

四、检查范围、调用堆栈和值

当进行逐行调试时,检查变量的范围和值以及函数调用的调用堆栈。在Debugger区可以这三个选项:

1ddb331787fcf3e71595ea6cde97008d.png

1. 范围(Scope)

可以在 Scope 选项中查看局部范围和全局范围内的内容以及变量,还可以看到 this 的实时指向:

456c622b3aa632f2d2ed065e2cf6473e.png

2. 调用堆栈

调用堆栈面板有助于识别函数执行堆栈:

b34a47de528082a9ea45bbb696eabab1.png

3. 值

检查代码中的值是识别代码中错误的主要方法。在单步执行时,我们只需要将鼠标悬停在变量上即可检查值。

下面可以看到变量 name 在代码执行时的检查值:

566c934a6828ccc695067a45d39e0395.png

此外,我们可以选择打码的一部分作为表达式来检查值。在下面的例子中,选择了表达式document.getElementById('m_wish') 来检查值:

f10534a14e7d3e00450bfa0af66b36b7.png

4. Watch

Watch 部分允许添加一个或多个表达式,并在执行时监视它们的值。当我们想在代码逻辑之外进行一些计算时,这个功能非常有用。我们可以组合来自代码区域的任何变量,以形成有效的JavaScript表达式。在逐步执行时,就能看到表达式的值。

以下是添加 Watch 的步骤:

  1. 单击 Watch 上的 + 按钮:

886708aa871c34e22370073568763bf4.png

  1. 添加要监控的表达式。在这个例子中,添加了一个希望观察其值的变量:

e1313253ea52d7fb31a28e40340dd41f.png

另一种观察表达式值的方法是从控制台的console中添加:

02d4dcf677135d397caf571a928c901b.png

五、禁用和删除断点

可以点击以下按钮来禁用所有的断点:

06f4f827463ca589974c80e127cfa006.png注意,上述方法不会删除断点,只会在暂时停用它们。要再次激活这些断点,只需再点一次这个断点即可。

通过取消选中的复选框,可以从“Breakpoints”面板中删除一个或多个断点。通过右键单击并选择“删除所有断点”选项,可以删除所有断点:

22ba5f44bee8352ebcec0be4d5d616ef.png

六、使用 VS Code 调试 JavaScript

Visual Studio code 中一些实用的插件可以用于 JavaScript 代码的调试。可以安装一个名为“Debugger for Chrome”的插件来调试代码:

69ca3a39b22fee51420d09422e9d0c11.png

安装之后,单击左侧的 run 选项并创建配置以运行/调试 JavaScript 应用程序。

113c6798de24bb29a0231242408cf0ef.png

这样就会创建一个名为 launch.json 的文件,其中包含一些设置信息:

{
  "version": "0.2.0",
  "configurations": [
      {
          "type": "chrome",
          "request": "launch",
          "name": "Debug the Greet Me app",
          "url": "<http://localhost:5500>",
          "webRoot": "${workspaceFolder}"
      }
  ]
}
登录后复制

可以修改以下参数:

  • name : 任意名称;

  • url:本地运行的 URL;

  • webRoot:默认值为 ${workspaceFolder},即当前文件夹。可能将其更改为 项目入口文件即可。

最后一步是通过单击左上角的播放图标开始调试:

d9c1f71e20364cc2954a4c8050afeed1.png

这个调试器类似于DevTools,主要有以下部分:

  1. 启用调试。按播放按钮启用调试选项。

  2. 用于单步执行断点以及暂停或停止调试的控件。

  3. 在源代码上设置断点。

  4. 范围面板查看变量范围和值。

  5. 用于创建和监视表达式的监视面板。

  6. 执行函数的调用栈。

  7. 要启用、禁用和删除的断点列表。

  8. 调试控制台读取控制台日志消息。

e14f08a6a9f98d84fdbd7c38fff101ee.png

最后,回到最开始的问题,这里不再一步步调试,通过上述的调试方法判定,只需要在 wish 变量前面加一个 + 即可:

const message = &#39;Hello &#39; 
                        + name 
                        + &#39;, Your wish `&#39; 
                        + + wish 
                        + &#39;` may come true!&#39;;
登录后复制

相关推荐:javascript学习教程

以上是超实用的JavaScript调试技巧的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何使用WebSocket和JavaScript实现在线语音识别系统 如何使用WebSocket和JavaScript实现在线语音识别系统 Dec 17, 2023 pm 02:54 PM

如何使用WebSocket和JavaScript实现在线语音识别系统引言:随着科技的不断发展,语音识别技术已经成为了人工智能领域的重要组成部分。而基于WebSocket和JavaScript实现的在线语音识别系统,具备了低延迟、实时性和跨平台的特点,成为了一种被广泛应用的解决方案。本文将介绍如何使用WebSocket和JavaScript来实现在线语音识别系

WebSocket与JavaScript:实现实时监控系统的关键技术 WebSocket与JavaScript:实现实时监控系统的关键技术 Dec 17, 2023 pm 05:30 PM

WebSocket与JavaScript:实现实时监控系统的关键技术引言:随着互联网技术的快速发展,实时监控系统在各个领域中得到了广泛的应用。而实现实时监控的关键技术之一就是WebSocket与JavaScript的结合使用。本文将介绍WebSocket与JavaScript在实时监控系统中的应用,并给出代码示例,详细解释其实现原理。一、WebSocket技

如何使用WebSocket和JavaScript实现在线预约系统 如何使用WebSocket和JavaScript实现在线预约系统 Dec 17, 2023 am 09:39 AM

如何使用WebSocket和JavaScript实现在线预约系统在当今数字化的时代,越来越多的业务和服务都需要提供在线预约功能。而实现一个高效、实时的在线预约系统是至关重要的。本文将介绍如何使用WebSocket和JavaScript来实现一个在线预约系统,并提供具体的代码示例。一、什么是WebSocketWebSocket是一种在单个TCP连接上进行全双工

如何利用JavaScript和WebSocket实现实时在线点餐系统 如何利用JavaScript和WebSocket实现实时在线点餐系统 Dec 17, 2023 pm 12:09 PM

如何利用JavaScript和WebSocket实现实时在线点餐系统介绍:随着互联网的普及和技术的进步,越来越多的餐厅开始提供在线点餐服务。为了实现实时在线点餐系统,我们可以利用JavaScript和WebSocket技术。WebSocket是一种基于TCP协议的全双工通信协议,可以实现客户端与服务器的实时双向通信。在实时在线点餐系统中,当用户选择菜品并下单

JavaScript和WebSocket:打造高效的实时天气预报系统 JavaScript和WebSocket:打造高效的实时天气预报系统 Dec 17, 2023 pm 05:13 PM

JavaScript和WebSocket:打造高效的实时天气预报系统引言:如今,天气预报的准确性对于日常生活以及决策制定具有重要意义。随着技术的发展,我们可以通过实时获取天气数据来提供更准确可靠的天气预报。在本文中,我们将学习如何使用JavaScript和WebSocket技术,来构建一个高效的实时天气预报系统。本文将通过具体的代码示例来展示实现的过程。We

简易JavaScript教程:获取HTTP状态码的方法 简易JavaScript教程:获取HTTP状态码的方法 Jan 05, 2024 pm 06:08 PM

JavaScript教程:如何获取HTTP状态码,需要具体代码示例前言:在Web开发中,经常会涉及到与服务器进行数据交互的场景。在与服务器进行通信时,我们经常需要获取返回的HTTP状态码来判断操作是否成功,根据不同的状态码来进行相应的处理。本篇文章将教你如何使用JavaScript获取HTTP状态码,并提供一些实用的代码示例。使用XMLHttpRequest

javascript中如何使用insertBefore javascript中如何使用insertBefore Nov 24, 2023 am 11:56 AM

用法:在JavaScript中,insertBefore()方法用于在DOM树中插入一个新的节点。这个方法需要两个参数:要插入的新节点和参考节点(即新节点将要被插入的位置的节点)。

如何在JavaScript中获取HTTP状态码的简单方法 如何在JavaScript中获取HTTP状态码的简单方法 Jan 05, 2024 pm 01:37 PM

JavaScript中的HTTP状态码获取方法简介:在进行前端开发中,我们常常需要处理与后端接口的交互,而HTTP状态码就是其中非常重要的一部分。了解和获取HTTP状态码有助于我们更好地处理接口返回的数据。本文将介绍使用JavaScript获取HTTP状态码的方法,并提供具体代码示例。一、什么是HTTP状态码HTTP状态码是指当浏览器向服务器发起请求时,服务

See all articles