Chrome开发者工具实战:调试三剑客

在前端开发的世界里,Chrome开发者工具就是我们的瑞士军刀,它集成了各种强大的功能,帮助我们快速定位和解决代码中的问题。今天,就让我们一起来看看如何使用Chrome开发者工具中的“调试三剑客”:断点调试、调用栈跟踪和控制台输出变量。

一、断点调试:代码的“检查站”

断点调试就像是在高速公路上设置的检查站,当代码执行到某个特定位置时,它会停下来,让我们可以查看当前的变量值、调用栈等信息,看看代码是否按预期运行。

1. 设置断点

在Chrome开发者工具中,打开“Sources”面板,找到你要调试的JavaScript文件。点击代码行号的左侧,设置一个断点。当代码执行到这一行时,会自动暂停。

2. 暂停与恢复

代码暂停后,你可以查看当前的变量值、调用栈等信息。点击“Resume script execution”按钮(或按F8),代码将继续执行。

3. 单步调试
  • Step Over:执行当前行,不进入函数内部。

  • Step Into:进入当前行调用的函数内部。

  • Step Out:执行完当前函数并退出。

4. 条件断点

仅在您提供的条件为 true 时触发的条件断点。例如,只有在某个变量达到特定值时才暂停代码执行。

let count = 0;
while (count < 10) {count++;// 在这里设置条件断点,当 count === 5 时暂停
}
5. 异常断点

在捕获的异常或未捕获的异常上设置断点。这可以帮助你快速定位到代码中抛出异常的地方。

案例:异常断点

function divide(a, b) {if (b === 0) {throw new Error("除数不能为零");}return a / b;
}function calculate() {let result = divide(10, 0); // 这里会抛出异常return result;
}calculate();

调试步骤:

  1. 打开Chrome开发者工具,切换到“Sources”面板。

  2. 在“Debugger”部分,找到“Breakpoints”选项。

  3. 勾选“Pause on exceptions”选项。

  4. 执行代码,当代码抛出异常时,开发者工具会自动暂停在抛出异常的行。

6. XHR断点

当请求的网址与您提供的子字符串匹配时触发的XHR断点。这在调试网络请求时非常有用。

案例:XHR断点

function fetchData() {let xhr = new XMLHttpRequest();xhr.open("GET", "https://api.example.com/data");xhr.onload = function() {console.log("Data loaded:", xhr.responseText);};xhr.send();
}fetchData();

调试步骤:

  1. 打开Chrome开发者工具,切换到“Sources”面板。

  2. 在“Debugger”部分,找到“XHR/Breakpoints”选项。

  3. 输入要匹配的URL子字符串,例如“example.com”。

  4. 执行代码,当发送匹配的XHR请求时,开发者工具会自动暂停。

二、调用栈跟踪:代码的“侦探”

调用栈跟踪就像是侦探破案时的线索追踪,它记录了函数调用的顺序,帮助我们找到代码中的“罪魁祸首”。

案例:调用栈跟踪

function add(a, b) {return a + b;
}function multiply(a, b) {return a * b;
}function calculate() {let sum = add(5, 10);let product = multiply(sum, 2);return product;
}calculate();

调试步骤:

  1. 打开Chrome开发者工具,切换到“Sources”面板。

  2. multiply函数内部设置一个断点。

  3. 执行代码,当代码暂停时,打开“Call Stack”面板。

  4. 查看调用栈,可以看到函数调用的顺序:calculate  -> multiply

  5. 点击调用栈中的某一行,可以跳转到对应的函数定义处。

三、控制台输出变量:实时查看变量值

控制台输出变量就像是给代码加了一个“监视器”,可以实时查看变量的值,帮助我们了解代码的运行状态。

1. 输出变量

在代码中使用console.log()console.info()console.warn()console.error()等方法输出变量。

let name = "John";
let age = 30;
console.log("Name:", name);
console.log("Age:", age);
2. 查看输出

打开Chrome开发者工具的“Console”面板,查看输出的变量值。

3. 条件输出

可以使用console.log()的条件输出功能,只在满足特定条件时输出变量。

let age = 30;
if (age > 25) {console.log("Age is greater than 25:", age);
}

四、实战示例

下面是一个综合示例,展示如何使用Chrome开发者工具进行调试:

function calculateSum(a, b) {let sum = a + b;console.log("Sum:", sum); // 输出变量return sum;
}function main() {let a = 5;let b = 10;let result = calculateSum(a, b);return result;
}// 设置断点
let finalResult = main();

调试步骤:

  1. 打开Chrome开发者工具,切换到“Sources”面板。

  2. 找到包含上述代码的文件,点击main函数内部的某一行设置断点。

  3. 执行代码,当代码暂停时,查看调用栈和变量值。

  4. 使用单步调试功能,逐步执行代码,观察变量的变化。

  5. 查看“Console”面板中的输出,确认变量值是否符合预期。

五、总结

Chrome开发者工具中的断点调试、调用栈跟踪和控制台输出变量是web逆向的得力助手。通过这工具,我们可以快速逆向得到的算法和逻辑是否正确。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/76498.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

函数柯里化(Currying)介绍(一种将接受多个参数的函数转换为一系列接受单一参数的函数的技术)

文章目录 柯里化的特点示例普通函数柯里化实现使用Lodash进行柯里化 应用场景总结 函数柯里化&#xff08;Currying&#xff09;是一种将接受多个参数的函数转换为一系列接受单一参数的函数的技术。换句话说&#xff0c;柯里化将一个多参数函数转化为一系列嵌套的单参数函数。 …

torch.nn中的非线性激活介绍合集——Pytorch中的非线性激活

1、nn.ELU 基本语法&#xff1a; class torch.nn.ELU(alpha1.0, inplaceFalse)按元素应用 Exponential Linear Unit &#xff08;ELU&#xff09; 函数。 论文中描述的方法&#xff1a;通过指数线性单元 &#xff08;ELU&#xff09; 进行快速准确的深度网络学习。 ELU 定义为…

Databend Cloud Dashboard 全新升级:直击痛点,释放数据价值

自 Databend Cloud 上线以来&#xff0c;我们一直致力于为用户提供高效的数据处理与可视化体验。早期&#xff0c;我们在工作区的“图表”区域推出了轻量级可视化功能&#xff0c;支持积分卡、饼图、柱状图和折线图四种展示方式。这些功能简单易用&#xff0c;基本满足了用户对…

Android Fresco 框架扩展模块源码深度剖析(四)

Android Fresco 框架扩展模块源码深度剖析 一、引言 在 Android 开发领域&#xff0c;图片处理一直是一个重要且具有挑战性的任务。Fresco 作为 Facebook 开源的强大图片加载框架&#xff0c;在图片的加载、缓存和显示等方面已经提供了非常完善的功能。然而&#xff0c;为了满…

蓝桥杯最后十天冲刺 day 2 双指针的思想

双指针思想介绍 双指针&#xff08;Two Pointers&#xff09;是一种在数组或链表等线性结构中常用的算法技巧&#xff0c;通过使用两个指针&#xff08;索引或引用&#xff09;以不同的速度或方向遍历数据结构&#xff0c;从而高效解决问题。双指针通常用于优化暴力解法&#…

Axure 使用笔记

1.Axure如何制作页面弹窗 https://blog.csdn.net/SDTechnology/article/details/143948691 2.axure 怎么点击按钮打开新页面 &#xff08;1&#xff09;新建交互 &#xff08;2&#xff09;单击是触发 &#xff08;3&#xff09;选择打开链接 &#xff08;4&#xff09;选择…

STM32实现一个简单电灯

新建工程的步骤 建立工程文件夹&#xff0c;Keil中新建工程&#xff0c;选择型号工程文件夹里建立Start、Library、User等文件夹&#xff0c;复制固件库里面的文件到工程文件夹工程里对应建立Start、Library、User等同名称的分组&#xff0c;然后将文件夹内的文件添加到工程分组…

html5炫酷图片悬停效果实现详解

html5炫酷图片悬停效果实现详解 这里写目录标题 html5炫酷图片悬停效果实现详解项目介绍技术栈核心功能实现1. 页面布局2. 图片容器样式3. 炫酷悬停效果缩放效果倾斜效果模糊效果旋转效果 4. 悬停文字效果5. 性能优化6. 响应式设计 项目亮点总结 项目介绍 本文将详细介绍如何使…

Playwright与Browser Use:领略AI赋能UI自动化测试的魔法魅力

目录 Browser Use是什么&#xff1f; Playwright简介 框架设计的核心目标与原则 Playwright 在 UI 自动化测试中的优势 如何高效拦截错误 实现视频录制 UI自动化框架设计的挑战 测试框架的结构与模块化设计 自动化测试不是银弹 走进Browser Use 横空出世的背景与意义…

Uniapp 实现微信小程序滑动面板功能详解

文章目录 前言一、功能概述二、实现思路三、代码实现总结 前言 Uniapp 实现微信小程序滑动面板功能详解 一、功能概述 滑动面板是移动端常见的交互组件&#xff0c;通常用于在页面底部展开内容面板。本文将介绍如何使用 Uniapp 开发一个支持手势滑动的底部面板组件&#xff0…

【FAQ】HarmonyOS SDK 闭源开放能力 —Push Kit(12)

1.问题描述&#xff1a; pushdeviceid的长度是固定的吗&#xff1f; 解决方案&#xff1a; 在鸿蒙系统中&#xff0c;设备ID的长度是固定的。 2.问题描述&#xff1a; 通过REST API三方推送IM类消息&#xff0c;如何实现应用处于前台时不展示三方推送通知。 解决方案&…

【小兔鲜】day02 Pinia、项目起步、Layout

【小兔鲜】day02 Pinia、项目起步、Layout 1. Pinia2. 添加Pinia到Vue项目3. 案例&#xff1a;Pinia-counter基础使用3.1 Store 是什么&#xff1f;3.2 应该在什么时候使用 Store? 4. Pinia-getters和异步action4.1 getters4.2 action如何实现异步 1. Pinia Pinia 是 Vue 的专…

Android学习之计算器app(java + 详细注释 + 源码)

运行结果&#xff1a; 基础的四则运算&#xff1a; 可能会出现的问题以及解决方法&#xff1a; 问题1&#xff1a;出现多个操作符。 例子&#xff1a;12 解决方法&#xff1a; 在用户点击操作符之后&#xff0c;去检查之前的最后一位&#xff0c;如果最后一位也是操作符的话…

GMap.NET + WPF:构建高性能 ADS-B 航空器追踪平台

ADS-B 简介 ADS - B&#xff08;Automatic Dependent Surveillance - Broadcast&#xff0c;广播式自动相关监视&#xff09;是一种先进的航空监视技术。它依靠飞机上的机载设备&#xff0c;自动收集诸如飞机的位置、高度、速度、航向等关键数据&#xff0c;并周期性地以广播的…

关于testng.xml无法找到类的问题

问题&#xff1a;testng.xml添加测试类的时候飘红 解决办法&#xff1a; 1.试图通过自动生成testng.xml插件去解决&#xff0c;感觉也不是这个问题&#xff0c;没有尝试&#xff1b; 2.以为是创建包的方式不对&#xff0c;重新删除后新建--还是找不到 想新建类的时候发现从m…

数据在内存中存储(C语言)

文章目录 前言一、整数在内存中的存储1.1 计算机存储数据的基本单位示例代码 1.2 无符号整数的存储1.3 有符号整数的存储&#xff08;补码&#xff09;示例代码 二、大小端字节序和字节序判断2.1 什么是大小端&#xff1f;示例代码 2.2 为什么会有大小端&#xff1f;2.3 字节序…

Python爬虫第2节-网页基础和爬虫基本原理

目录 一、网页基础 1.1 网页的组成 1.2 网页的结构 1.3 节点树及节点间的关系 1.4 选择器 二、爬虫的基本原理 2.1 爬虫概述 2.2 能抓怎样的数据 2.3 JavaScript 渲染页面 一、网页基础 使用浏览器访问网站时&#xff0c;我们会看到各式各样的页面。你是否思考过&…

python-leetcode 64.在排序数组中查找元素的第一个和最后一个位置

题目&#xff1a; 给一个按照非递减顺序排列的整数数组nums,和一个目标值target,请找出给定目标值在数组中的开始位置和结束位置。 如果数组中不存在目标值target,返回[-1,-1] 方法一&#xff1a;二分查找 直观的思路肯定是从前往后遍历一遍。用两个变量记录第一次和最后一次…

分享一些新版GPT-4o使用方式!能多模态生图!

目前GPT-4o的整体测评&#xff0c;真的很惊艳。 不知道又有多少人因为OpenAI的这次更新而失业&#xff0c;当然只要AI用得好&#xff0c;会有更多人因之而受益&#xff01;很多人表示不知道怎么用&#xff0c;对于门外汉来说&#xff0c;4o似乎有点高端。 今天就给大家介绍几…

软件工程面试题(二十四)

1、连接池的原理 j2ee 服务器启动时会建立一定数量的池连接,并一直维持不少于此数量的池连接。当客户端程序需要连接时,吃驱动程序会返回一个未使用的池连接并将其标记为忙。如果当前 没有空闲连接,池驱动就建立一定新的 连接 2、用javascript编写脚本小程序,实现点击全选…