”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 像专业人士一样调试 JavaScript 代码

像专业人士一样调试 JavaScript 代码

发布于2024-08-23
浏览:764

调试是软件开发过程的重要组成部分,因为它允许开发人员识别、理解和修复代码中的错误和意外行为,确保软件正确有效地运行。掌握它可以显着提高您的工作效率和代码质量。这是一个深入的指南,可以帮助您像专业人士一样调试 JavaScript 代码:

1。控制台日志记录

  • console.log(): 最基本的调试形式。用它来打印值并查看它们如何随时间变化。

  • console.error() 和 console.warn(): 用于突出显示错误和警告。

  • console.table(): 以表格形式显示数组或对象数据,方便阅读。

Debugging JavaScript Code Like a Pro

2.调试器语句
可以将调试器语句插入到代码中以在特定点暂停执行。当浏览器遇到这个语句时,它会停止并打开调试工具。

Debugging JavaScript Code Like a Pro

3.浏览器开发者工具

Chrome 开发工具

  • 元素面板:检查和修改 HTML 和 CSS。

  • 控制台面板: 动态执行 JavaScript、查看日志消息以及与 JavaScript 环境交互。

  • 源面板:设置断点、单步执行代码并检查变量。

  • 网络面板:分析网络请求和响应。

  • 性能面板:测量和分析性能瓶颈。

4。设置断点
设置断点是一种基本的调试技术,它允许您在特定点暂停代码的执行。通过此暂停,您可以检查应用程序的当前状态,包括变量值和执行流程。

断点类型

  • 行断点: 最常见的类型。您可以通过单击代码编辑器或浏览器的开发人员工具中的行号来设置它们。当执行到达此行时,它会暂停,允许您检查当前状态。

  • 条件断点:
    这些断点仅在指定条件为真时暂停执行。它对于仅在满足某些条件时停止代码执行非常有用,从而减少不必要的暂停。

  • 函数断点: 每当调用特定函数时自动设置为暂停。当您想要检查函数每次执行时的行为时,这会很有帮助。

  • DOM 断点: 在特定 DOM 元素上设置,以便在该元素上发生特定事件(例如属性修改、节点删除)时暂停执行。它对于调试动态 DOM 更改很有用。

5。观看表达式
您可以在调试工具中添加监视表达式,以跟踪特定变量或表达式随时间的变化。

  1. 打开源面板。
  2. 右键单击“监视”部分并选择“添加监视表达式”。
  3. 输入您想观看的表情。

6。错误处理
正确的错误处理可以防止应用程序崩溃并使调试更容易。

  • try...catch: 用于处理异常。

Debugging JavaScript Code Like a Pro

  • 自定义错误消息:提供有意义的错误消息以使调试更容易。

Debugging JavaScript Code Like a Pro

7. Linting 工具
像 ESLint 这样的 Linting 工具可以捕获潜在的错误并强制执行编码标准,从而减少出现错误的可能性。

Debugging JavaScript Code Like a Pro

流行的 Linting 工具

  1. ESLint
  2. JSHint
  3. 更漂亮

8。单元测试
单元测试涉及为代码的各个单元或组件编写测试,以确保它们按预期工作。它有助于及早发现错误并使您的代码更可靠且更容易重构。

Debugging JavaScript Code Like a Pro

流行的测试框架

  1. 笑话
  2. 摩卡
  3. 茉莉花

9。网络和性能调试

网络面板

  • 检查请求:查看网络请求的详细信息,包括URL、方法、状态、响应和时间。

  • 计时:分析请求完成所需的时间并识别瓶颈。

性能面板

  • 录制表演:开始录制表演以捕捉事件的时间线。

  • 识别瓶颈:查找可能会降低性能的长任务、布局颠簸或过度回流。

  • 分析火焰图:了解任务随时间的执行情况并确定需要优化的领域。

10.分析和内存管理
使用性能和内存面板来识别和修复性能瓶颈和内存泄漏。

堆快照

  • 获取堆快照:捕获应用程序在不同点的内存使用情况。

  • 比较快照:比较多个快照以识别正在泄漏内存的对象。

分配时间表

  • 监视内存分配: 随着时间的推移跟踪内存分配,以查看应用程序在哪里使用最多的内存。

  • 识别内存使用过多:查找内存分配中的峰值并确定代码的哪些部分是有问题的。

结论
有效地调试 JavaScript 需要结合正确的工具、技术和有条不紊的方法。通过利用现代浏览器开发人员工具的功能、编写清晰且可维护的代码以及使用自动化测试,您可以更有效地识别和修复错误。
请分享您对此的看法。调试愉快!

版本声明 本文转载于:https://dev.to/khushboo-tolat/debugging-javascript-code-like-a-pro-267h?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 破解编码面试的热门必备书籍(从初级到高级排名)
    破解编码面试的热门必备书籍(从初级到高级排名)
    准备编码面试可能是一个充满挑战的旅程,但拥有正确的资源可以让一切变得不同。无论您是从算法开始的初学者、专注于系统设计的中级开发人员,还是完善编码实践的高级工程师,这份按难度排名的前 10 本书列表都将为您提供成功所需的知识和技能。你的软件工程面试。这些书籍涵盖了从基本算法到系统设计和简洁编码原则的所...
    编程 发布于2024-11-06
  • Java 字符串实习初学者指南
    Java 字符串实习初学者指南
    Java String Interning 引入了通过在共享池中存储唯一字符串来优化内存的概念,减少重复对象。它解释了 Java 如何自动实习字符串文字以及开发人员如何使用 intern() 方法手动将字符串添加到池中。 通过掌握字符串驻留,您可以提高 Java 应用程序的性能和内存效率。要深入...
    编程 发布于2024-11-06
  • 如何在 GUI 应用程序中的不同页面之间共享变量数据?
    如何在 GUI 应用程序中的不同页面之间共享变量数据?
    如何从类中获取变量数据在 GUI 编程环境中,单个应用程序窗口中包含多个页面是很常见的。每个页面可能包含各种小部件,例如输入字段、按钮或标签。当与这些小部件交互时,用户提供输入或做出需要在不同页面之间共享的选择。这就提出了如何从一个类访问另一个类的变量数据的问题,特别是当这些类代表不同的页面时。利用...
    编程 发布于2024-11-06
  • React 中的动态路由
    React 中的动态路由
    React 中的动态路由允许您基于动态数据或参数创建路由,从而在应用程序中实现更灵活、更强大的导航。这对于需要根据用户输入或其他动态因素呈现不同组件的应用程序特别有用。 使用 React Router 设置动态路由 您通常会使用react-router-dom库在React中实现动态路由。这是分步指...
    编程 发布于2024-11-06
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-06
  • WPF中延迟操作时如何避免UI冻结?
    WPF中延迟操作时如何避免UI冻结?
    WPF 中的延迟操作WPF 中的延迟操作对于增强用户体验和确保平滑过渡至关重要。一种常见的情况是在导航到新窗口之前添加延迟。为了实现此目的,经常使用 Thread.Sleep,如提供的代码片段中所示。但是,在延迟过程中,使用 Thread.Sleep 阻塞 UI 线程会导致 UI 无响应。这表现为在...
    编程 发布于2024-11-06
  • 利用 Java 进行实时数据流和处理
    利用 Java 进行实时数据流和处理
    In today's data-driven world, the ability to process and analyze data in real-time is crucial for businesses to make informed decisions swiftly. Java...
    编程 发布于2024-11-06
  • 如何修复损坏的 InnoDB 表?
    如何修复损坏的 InnoDB 表?
    从 InnoDB 表损坏中恢复灾难性事件可能会导致数据库表严重损坏,特别是 InnoDB 表。遇到这种情况时,了解可用的修复选项就变得至关重要。InnoDB Table Corruption Symptoms查询中描述的症状,包括事务日志中的时间戳错误InnoDB 表的修复策略虽然已经有修复 MyI...
    编程 发布于2024-11-06
  • JavaScript 数组和对象中是否正式允许使用尾随逗号?
    JavaScript 数组和对象中是否正式允许使用尾随逗号?
    数组和对象中的尾随逗号:标准还是容忍?数组和对象中尾随逗号的存在引发了一些关于它们的争论JavaScript 的标准化。这个问题源于在不同浏览器中观察到的不一致行为,特别是旧版本的 Internet Explorer。规范状态根据 ECMAScript 5 规范(第 11.1.5 节) ),对象字面...
    编程 发布于2024-11-06
  • 最佳引导模板生成器
    最佳引导模板生成器
    在当今快速发展的数字环境中,速度和效率是关键,网页设计师和开发人员越来越依赖 Bootstrap 构建器来简化他们的工作流程。这些工具可以快速创建响应灵敏、具有视觉吸引力的网站,使团队能够比以往更快地将他们的想法变为现实。 Bootstrap 构建器真正改变了网站的构建方式,使该过程更加易于访问和高...
    编程 发布于2024-11-06
  • 简化 NestJS 中的文件上传:无需磁盘存储即可高效内存中解析 CSV 和 XLSX
    简化 NestJS 中的文件上传:无需磁盘存储即可高效内存中解析 CSV 和 XLSX
    Effortless File Parsing in NestJS: Manage CSV and XLSX Uploads in Memory for Speed, Security, and Scalability Introduction Handling file uploa...
    编程 发布于2024-11-06
  • 使用 SubDomainRadar.io 和 Python 轻松发现隐藏子域
    使用 SubDomainRadar.io 和 Python 轻松发现隐藏子域
    作为网络安全专业人员、漏洞赏金猎人或渗透测试人员,发现隐藏的子域对于识别至关重要域中的潜在漏洞。子域通常托管可能容易受到攻击的被遗忘的服务或测试环境。 在这篇文章中,我将向您介绍 SubDomainRadar.io 及其 Python API 包装器 — 自动化子域枚举的终极工具 和 安全工作流程...
    编程 发布于2024-11-06
  • Python 中的 HackerRank 问题 - 基本数据类型列表
    Python 中的 HackerRank 问题 - 基本数据类型列表
    此 Python 代码旨在根据用户提供的命令对列表执行一系列操作。让我们一步步分析代码,了解其工作原理: if __name__ == '__main__': N = int(input()) l = [] while(N>0): cmd_l = inp...
    编程 发布于2024-11-06
  • ust-Know 高级 Tailwind CSS 实用程序可增强开发体验
    ust-Know 高级 Tailwind CSS 实用程序可增强开发体验
    Tailwind CSS 以其实用性优先的方法而闻名,使开发人员能够直接在 HTML 中创建高度可定制的设计。除了基础知识之外,掌握高级实用程序还可以显着增强您的开发工作流程,使其更快、更高效。在这里,我们将探索每个开发人员都应该知道的六个高级 Tailwind CSS 实用程序,并通过并排代码编辑...
    编程 发布于2024-11-06
  • Qt Signals 中的 DirectConnection 与 QueuedConnection:何时应该选择哪个?
    Qt Signals 中的 DirectConnection 与 QueuedConnection:何时应该选择哪个?
    Qt 信号:深入研究 DirectConnection 和 QueuedConnectionQt 信号在 Qt 应用程序中组件之间的通信中发挥着至关重要的作用。然而,选择 DirectConnection 和 QueuedConnection 作为连接方法可能会产生重大影响,尤其是在处理多线程应用程...
    编程 发布于2024-11-06

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3