0

我正在开发一个 Windows 窗体应用程序来解析和分析网页。我使用了网络浏览器控件。该网页有 html 和 javascript 代码波纹管。我的 windows 窗体有 c# 代码。这是代码:

HTML 代码:

<div id="div1" onclick='func1(this);'>
</div>
<div id="div2">
</div>
<div id="div3">
</div>

Javascript:

function func1(element) {
    ...
}
document.getElementById("div2").onclick = function foo() { doSomething(); }
document.getElementById("div3").addEventListener("click", anyFunc);

导航相关 URL 后,我的 Windows 窗体应用程序中的 C# 代码:

HtmlElement el1 = WebBrowser.Document.GetElementById("div1");
HtmlElement el2 = WebBrowser.Document.GetElementById("div2");
HtmlElement el3 = WebBrowser.Document.GetElementById("div3");
String el1JavaFunc = el1.GetAttribute("onClick");
String el2JavaFunc = el2.GetAttribute("onClick");
String el3JavaFunc = el3.GetAttribute("onClick");
// check if el1JavaFunc is empty or null
// check if el2JavaFunc is empty or null
// check if el3JavaFunc is empty or null

这样,在检查每个元素的相关字符串后,我可以确定该元素是否已分配 javascript 函数。这适用于 el1 和 el2,但它为 el3 返回空字符串。

我怎么知道第三个元素使用 addEventListener 分配了 javascript 函数?

4

3 回答 3

1

我建议始终调用 .addEventListener ,因为:

如果多个相同的 EventListener 在同一个 EventTarget 上注册了相同的参数,则重复的实例将被丢弃。它们不会导致 EventListener 被调用两次,也不需要使用 removeEventListener 方法手动删除。 https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener

于 2016-01-25T12:44:57.630 回答
0

就像这里提到的:检查一个元素上是否有事件监听器。没有jQuery

使用 JavaScript 无法确定元素是否正在侦听事件。最接近的是 getEventListeners(node),其中 node 是您要检查的元素。但是,这只能在 Google chrome 中使用,并且只能在控制台中使用。所以它不能在生产中使用。

于 2016-01-25T12:47:50.527 回答
0

DOM 不提供任何 API 来检索所有 eventListener 的列表(参考)所以不能那样做。

也许您可以控制执行 addEventListener() 的代码?然后您可以在那里创建一个侦听器列表并稍后使用该列表。

于 2016-01-25T12:48:39.260 回答