4

我正在尝试测试以下 JavaScript 代码,该代码旨在跟踪用户在多项选择调查中的响应时间:

document.onclick = function(e) {

    var event = e || window.event;    
    var target = e.target || e.srcElement;

    //time tracking 
    var ClickTrackDate = new Date;
    var ClickData = ""; 
    ClickData = target.id + "=" + ClickTrackDate.getUTCHours() + ":" + 
        ClickTrackDate.getUTCMinutes() + ":" +
        ClickTrackDate.getUTCSeconds() +";";

    document.getElementById("txtTest").value += ClickData;
    alert(target.id); // for testing
}

通常 target.id 等于被点击元素的 id,如你所料,但有时 target.id 是空的,看似随机,有什么想法吗?

4

2 回答 2

8

可能是因为被点击的元素没有 ID。例如,如果您有这样的 HTML,就会发生这种情况:

<div id="example">This is some <b>example</b> text.</div>

并且有人点击了粗体字“example”,因此事件目标将是b元素而不是div.

您可以尝试向上遍历 DOM 树,直到找到一个确实具有 ID 的元素,如下所示:

var target = e.target || e.srcElement;

while (target && !target.id) {
    target = target.parentNode;
}
// at this point target either has an ID or is null
于 2012-03-25T21:35:54.510 回答
3

只需使用e.currentTarget而不是e.target.

于 2018-12-02T16:31:38.447 回答