当前位置: 首页 > news >正文

前端开发者必备:揭秘谷歌F12调试的隐藏技巧!

前言

使用断点(breakpoint)是调试 JavaScript 代码的一种非常有效的方式。通过在代码的关键位置设置断点,可以阻止页面的状态变化,从而方便地检查和修改页面的当前状态。

1. 使用 setTimeout 配合 debuggerconsole.log

setTimeout(() => { console.log('Pause for debugging');debugger; 
}, 2000);

这种方法和之前描述的类似,但增加了一个 console.log,让你知道什么时候触发调试器。

演示

在这里插入图片描述

在这里插入图片描述

2. 在事件监听器中添加 debugger

在控制台中添加临时的事件监听器,并在监听器中加入 debugger

例如,如果你的元素有一个 ID 为 myElement,那么选择器应该是 '#myElement'

document.querySelector('your-selector').addEventListener('click', function() {debugger;
});

演示

在这里插入图片描述

在这里插入图片描述

这样,当你点击指定元素时,调试器会自动触发。

3. 使用 setInterval 监控状态变化

通过 setInterval 定时检查某个状态或元素变化,并在条件满足时触发 debugger

const interval = setInterval(() => {const dropdown = document.querySelector('your-dropdown-selector');if (dropdown && dropdown.style.display !== 'none') {console.log('Dropdown is now visible');debugger;clearInterval(interval);}
}, 100);

演示

在这里插入图片描述

这种方法适用于需要监控某个元素状态变化的场景。

4. 使用 monitorEvents

monitorEvents 是一个非常有用的工具,可以用来监控指定元素上的所有事件。

const element = document.querySelector('your-element-selector');
monitorEvents(element);

演示

在这里插入图片描述

这样你可以看到所有触发在该元素上的事件。

5. 使用 getEventListeners

这个方法可以列出某个元素上所有的事件监听器。

const element = document.querySelector('your-element-selector');
console.log(getEventListeners(element));

演示

在这里插入图片描述

这可以帮助你找到并理解元素上的所有事件绑定。

6. 更改元素状态

你可以直接在控制台中更改元素状态,以便持续显示某些元素。

const dropdown = document.querySelector('your-dropdown-selector');
dropdown.style.display = 'block';

演示

在这里插入图片描述

7. 强制伪类状态

在 Elements 面板中,右键点击你想要调试的元素,选择 Force Element State,然后选择 :hover:focus:active 等伪类。

演示

在这里插入图片描述

8. 使用 breakpoint 阻止页面状态变化

在 Sources 面板中,通过右键点击某个 JavaScript 文件的行号,添加断点。你可以在关键的事件处理函数或状态变化函数上添加断点,以便在需要时暂停执行。

演示

在这里插入图片描述

9. 使用 XHR/Fetch 断点

在 Sources 面板的右侧,找到 XHR Breakpoints,点击 + 号添加一个断点。输入你想要监控的 URL 关键字,当这个 URL 发起请求时,调试器会自动触发。

演示

在这里插入图片描述

10. 使用 DOM Mutation 断点

在 Elements 面板中,右键点击某个元素,选择 Break on,然后选择以下三种断点之一:

  • Subtree modifications:子树变化时触发断点。
  • Attributes modifications:属性变化时触发断点。
  • Node removal:节点被移除时触发断点。

演示

在这里插入图片描述

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • PixelMaster - 图片像素化终极利器 !
  • U盘数据恢复不再难:2024年4款工具,找回你“躲藏”的记忆
  • BootStrap前端面试常见问题
  • 【刷题汇总 -- 爱吃素、相差不超过k的最多数、最长公共子序列(一)】
  • 常回家看看之fastbin_attack
  • JVM知识体系梳理
  • PTA—基础编程题目集(7-18)
  • 【2024蓝桥杯/C++/B组/小球反弹】
  • 第五十八天 第十一章:图论part08 拓扑排序精讲 dijkstra(朴素版)精讲
  • 工业大数据通过哪些方式实现价值?详解实施工业大数据的难点!
  • 数据采集器
  • Python变量和简单的数据类型
  • AUTOSAR介绍
  • 打造前端开发的利器--NPM
  • PHP中的魔术常量(如__FILE__,__LINE__)及其用途
  • 【JavaScript】通过闭包创建具有私有属性的实例对象
  • 5、React组件事件详解
  • C# 免费离线人脸识别 2.0 Demo
  • export和import的用法总结
  • js ES6 求数组的交集,并集,还有差集
  • Mysql数据库的条件查询语句
  • Next.js之基础概念(二)
  • PHP的类修饰符与访问修饰符
  • Selenium实战教程系列(二)---元素定位
  • Vue官网教程学习过程中值得记录的一些事情
  • 首页查询功能的一次实现过程
  • 算法---两个栈实现一个队列
  • 阿里云IoT边缘计算助力企业零改造实现远程运维 ...
  • ​​​​​​​​​​​​​​汽车网络信息安全分析方法论
  • #define,static,const,三种常量的区别
  • #HarmonyOS:基础语法
  • #我与Java虚拟机的故事#连载13:有这本书就够了
  • (4)Elastix图像配准:3D图像
  • (pojstep1.1.1)poj 1298(直叙式模拟)
  • (PWM呼吸灯)合泰开发板HT66F2390-----点灯大师
  • (搬运以学习)flask 上下文的实现
  • (附源码)springboot 个人网页的网站 毕业设计031623
  • (附源码)springboot宠物管理系统 毕业设计 121654
  • (区间dp) (经典例题) 石子合并
  • (十六)视图变换 正交投影 透视投影
  • (一)模式识别——基于SVM的道路分割实验(附资源)
  • (译)2019年前端性能优化清单 — 下篇
  • (转)Windows2003安全设置/维护
  • (转)从零实现3D图像引擎:(8)参数化直线与3D平面函数库
  • (转载)VS2010/MFC编程入门之三十四(菜单:VS2010菜单资源详解)
  • .[hudsonL@cock.li].mkp勒索加密数据库完美恢复---惜分飞
  • .net core 6 集成和使用 mongodb
  • .NET 中选择合适的文件打开模式(CreateNew, Create, Open, OpenOrCreate, Truncate, Append)
  • .NET/C# 使用 #if 和 Conditional 特性来按条件编译代码的不同原理和适用场景
  • .NET连接数据库方式
  • .Net小白的大学四年,内含面经
  • .NET中 MVC 工厂模式浅析
  • .Net中的设计模式——Factory Method模式
  • .vimrc 配置项
  • ?.的用法