1

可能的重复:
如何使用 FireBug(或类似工具)调试 Javascript/jQuery 事件绑定
如何在 DOM 节点上查找事件侦听器?

如何通过 JavaScript 检测哪些事件已绑定到 DOM 元素?在下面的示例中,我希望能够看到 click 事件已绑定在我的“可点击”跨度上,并且如果可能的话,可以从alert-line 进行调试。

我可以使用像 Firebug 这样的 Web 开发人员实用程序来做到这一点吗?

<html>
    <head>
         <title>Events bound with JavaScript</title>
         <script type="text/javascript"
             src="http://ajax.googleapis.com/ajax/libs/jquery/1.3/jquery.min.js"></script>
         <script type="text/javascript">
             $(document).ready(function() {
                 $("#clickable").click(function() {
                     alert("Clicked.");
                 });
             });
         </script>
    </head>
    <body>
         <span id="clickable">Click me</span>
    </body>
</html>
4

1 回答 1

1
// this function will return number of keys in object
function objectLenght (obj) {
    var len = 0;
    for (var key in obj) {
        len++;
    }
    return len;
}

var objWithClickEvents = [];

// iterate through all elements
$('*').each(function() {
    var clickEvents = $.data($(this)[0], 'events').click;
    if (objectLength(clickEvents) > 0) {
        objWithClickEvents[objWithClickEvents.length] = $(this);
    }
});

如果您愿意,请替换click为其他事件。

于 2009-07-23T15:27:42.247 回答