我需要调试一个web应用程序,使用jQuery做一些相当复杂和混乱的DOM操作。在某一时刻,一些绑定到特定元素的事件没有触发,只是停止工作。

如果我有编辑应用程序源代码的能力,我将深入并添加一堆Firebug console.log()语句和注释/取消注释代码段,以试图查明问题。但是让我们假设我不能编辑应用程序代码,并且需要使用Firebug或类似的工具完全在Firefox中工作。

Firebug非常擅长让我导航和操作DOM。不过,到目前为止,我还没有弄清楚如何使用Firebug进行事件调试。具体来说,我只想看到在给定时间绑定到特定元素的事件处理程序列表(使用Firebug JavaScript断点跟踪更改)。但是,要么Firebug没有看到绑定事件的能力,要么我太笨了,找不到它。: -)

有什么建议或想法吗?理想情况下,我只希望查看和编辑绑定到元素的事件,类似于我现在编辑DOM的方式。


当前回答

在最新的Chrome (v29)中使用DevTools,我发现这两个技巧对调试事件非常有帮助:

列出最后选择的DOM元素的jQuery事件 检查页面上的元素 在控制台中输入以下内容: 美元。_data($0, "events") //假设jQuery 1.7+ 它将列出所有与之相关的jQuery事件对象,展开感兴趣的事件,右键单击“handler”属性的函数,并选择“Show function definition”。它将打开包含指定函数的文件。 使用monitorEvents()命令

其他回答

参见如何在DOM节点上查找事件侦听器。

简而言之,假设在某一点上一个事件处理程序附加到你的元素(例如):$('#foo').click(function() {console.log('clicked!')});

你这样检查它:

jQuery 1.3.x var clickEvents = $('#foo').data("events").click; jQuery。每个(点击事件,函数(键,值){ Console.log (value) //打印"function() {Console.log ('clicked!')}" }) jQuery 1.4.x var clickEvents = $('#foo').data("events").click; jQuery。每个(点击事件,函数(键,handlerObj) { console.log(handlerObj.handler) //打印"function() {console.log('clicked!')}" })

参见jQuery.fn.data (jQuery内部存储处理程序的地方)。

jQuery 1.8.x var clickEvents = $ ._data($(“# foo”)[0],“事件”).click; jQuery。每个(点击事件,函数(键,handlerObj) { console.log(handlerObj.handler) //打印"function() {console.log('clicked!')}" })

你可以使用FireQuery。它在Firebug的HTML选项卡中显示附加到DOM元素的任何事件。它还显示通过$.data附加到元素的任何数据。

有一个很好的书签工具叫做Visual Event,它可以显示附加到元素上的所有事件。它为不同类型的事件(鼠标、键盘等)提供了颜色编码的高亮显示。当你将鼠标悬停在它们上时,它会显示事件处理程序的主体,它是如何附加的,以及文件/行号(在WebKit和Opera上)。您也可以手动触发该事件。

它不能找到每个事件,因为没有标准的方法来查找附加到元素上的事件处理程序,但它与jQuery、Prototype、MooTools、YUI等流行库一起工作。

Firebug 2现在集成了DOM事件调试/检查。

我还在chrome商店里找到了jQuery调试器。您可以单击一个dom项,它将显示所有绑定到该dom项的事件以及回调函数。我正在调试一个事件没有被正确删除的应用程序,这帮助我在几分钟内追踪到它。显然这是针对chrome,而不是firefox。