[英]Chrome DevTools: setting a breakpoint on document scroll change?
有时,在大型客户端 web 应用程序中,有必要通过scrollTo()
调用确定哪一行代码滚动了文档(或者这是否甚至是滚动*的原因)。
是否有任何 Chrome DevTools 功能会在窗口滚动时中断 JS 执行? 我正在想象一个类似于 DOM Breakpoints 功能的功能。
* 滚动也可能由于其他原因而发生,例如屏幕外<input>
中的文本输入。
您可以使用 JavaScript 事件侦听器断点。 在 Chrome 开发者工具的源选项卡中,找到“事件侦听器断点”,然后“滚动”断点位于“控制”下。
我使用它来覆盖/代理scroll
功能并在新功能中设置debugger
的方式。
我在控制台中运行以下代码片段,希望其中一个滚动函数会被调用:
const proxyFn = fnName => {
const oldFn = window[fnName];
window[fnName] = (...args) => {
debugger;
oldFn(...args)
}
}
Object.keys(window).filter(c => c.includes("scroll")).forEach(c => proxyFn(c))
// or, if you want to "catch" the "scrollTo" function
proxyFn("scrollTo")
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.