前端开发必备的谷歌F12调试JavaScript的隐藏技巧!

2024-08-0208:24:03WEB前端开发Comments411 views字数 1840阅读模式

前言

使用断点(breakpoint)是调试 JavaScript 代码的一种非常有效的方式。通过在代码的关键位置设置断点,可以阻止页面的状态变化,从而方便地检查和修改页面的当前状态。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

1. 使用 setTimeout 配合 debugger 和 console.log

js

代码解读
复制代码
setTimeout(() => { 
  console.log('Pause for debugging');
  debugger; 
}, 2000);

这种方法和之前描述的类似,但增加了一个 console.log,让你知道什么时候触发调试器。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

演示

前端开发必备的谷歌F12调试JavaScript的隐藏技巧!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

前端开发必备的谷歌F12调试JavaScript的隐藏技巧!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

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

在控制台中添加临时的事件监听器,并在监听器中加入 debugger文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

例如,如果你的元素有一个 ID 为 myElement,那么选择器应该是 '#myElement'文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

js

代码解读
复制代码
document.querySelector('your-selector').addEventListener('click', function() {
  debugger;
});

演示

前端开发必备的谷歌F12调试JavaScript的隐藏技巧!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

前端开发必备的谷歌F12调试JavaScript的隐藏技巧! 这样,当你点击指定元素时,调试器会自动触发。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

3. 使用 setInterval 监控状态变化

通过 setInterval 定时检查某个状态或元素变化,并在条件满足时触发 debugger文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

js

代码解读
复制代码
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);

演示

前端开发必备的谷歌F12调试JavaScript的隐藏技巧!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

这种方法适用于需要监控某个元素状态变化的场景。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

4. 使用 monitorEvents

monitorEvents 是一个非常有用的工具,可以用来监控指定元素上的所有事件。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

js

代码解读
复制代码
const element = document.querySelector('your-element-selector');
monitorEvents(element);

演示

前端开发必备的谷歌F12调试JavaScript的隐藏技巧!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

这样你可以看到所有触发在该元素上的事件。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

5. 使用 getEventListeners

这个方法可以列出某个元素上所有的事件监听器。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

js

代码解读
复制代码
const element = document.querySelector('your-element-selector');
console.log(getEventListeners(element));

演示

前端开发必备的谷歌F12调试JavaScript的隐藏技巧!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

这可以帮助你找到并理解元素上的所有事件绑定。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

6. 更改元素状态

你可以直接在控制台中更改元素状态,以便持续显示某些元素。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

js

代码解读
复制代码
const dropdown = document.querySelector('your-dropdown-selector');
dropdown.style.display = 'block';

演示

前端开发必备的谷歌F12调试JavaScript的隐藏技巧!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

7. 强制伪类状态

在 Elements 面板中,右键点击你想要调试的元素,选择 Force Element State,然后选择 :hover:focus:active 等伪类。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

演示

前端开发必备的谷歌F12调试JavaScript的隐藏技巧!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

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

在 Sources 面板中,通过右键点击某个 JavaScript 文件的行号,添加断点。你可以在关键的事件处理函数或状态变化函数上添加断点,以便在需要时暂停执行。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

演示

前端开发必备的谷歌F12调试JavaScript的隐藏技巧!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

9. 使用 XHR/Fetch 断点

在 Sources 面板的右侧,找到 XHR Breakpoints,点击 + 号添加一个断点。输入你想要监控的 URL 关键字,当这个 URL 发起请求时,调试器会自动触发。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

演示

前端开发必备的谷歌F12调试JavaScript的隐藏技巧!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

10. 使用 DOM Mutation 断点

在 Elements 面板中,右键点击某个元素,选择 Break on,然后选择以下三种断点之一:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

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

演示

前端开发必备的谷歌F12调试JavaScript的隐藏技巧!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html

作者:Yoo前端
链接:https://juejin.cn/post/7397024981572010023
来源:稀土掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/64700.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/gcs/64700.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定