gpt4 book ai didi

JavaScript - 事件 relatedTarget 不适用于 onClick

转载 作者:行者123 更新时间:2023-11-29 23:16:13 25 4
gpt4 key购买 nike

当我仅将 event.relatedTarget 用于 onClick 时出现错误,但它适用于 onMouseout。

这是我的代码:

<html>
<head>
<style type="text/css">
#layer1 {
width: 370px;
height: 220px;
background-color: yellow;
}
#layer2 {
position: relative;
width: 130px;
height: 47px;
top: 10px;
left: 10px;
background-color: #CC0066;
}
#layer3 {
position: relative;
width: 200px;
height: 100px;
top: 10px;
left: 150px;
background-color: #334466;
}

#button1 {
position: relative;
top: 4px;
left: 4px;
}

#button2 {
position: relative;
top: 4px;
left: 4px;
}
</style>
<body>
<div id="layer1">
<div id = "layer2">
<input type="submit" id = "button1" value="Button 1 (onclick)"></input>
</div>
<div id = "layer3">
<input type="submit" id = "button2" value="Button 2 (onmouseout)"></input>
</div>
</div>
<script type="text/javascript">
document.getElementsByTagName("body")[0].addEventListener("click", function() {print(event);}, false);
document.getElementsByTagName("div")[0].addEventListener("click", function() {print(event);}, false);
document.getElementsByTagName("div")[1].addEventListener("click", function() {print(event);}, false);
document.getElementsByTagName("input")[0].addEventListener("click", function() {print(event);}, false);

document.getElementsByTagName("div")[2].addEventListener("mouseout", function() {print(event);}, false);
document.getElementsByTagName("input")[1].addEventListener("mouseout", function() {print(event);}, false);
function print(elem) {
alert("JavaScript alert\n\n" +
"Element\n" +
" Type: " + elem.relatedTarget.tagName +
"\n Id: " + elem.relatedTarget.id +
"\nEvent's name: " + elem.type +
"\nMouse's coordinates" +
"\n Screen: " + elem.screenX + ", " + elem.screenY +
"\n Window: " + elem.clientX + ", " + elem.clientY +
"\n HTML item: " + elem.offsetX + ", " + elem.offsetY);
}
</script>
</body>
</html>

单击项目时出错:https://i.imgur.com/XKX2oaU.png

虽然,使用 mouseout 它可以正常工作:https://i.imgur.com/nmFGKkI.png

我不明白哪里出了问题,因为我使用的是相同的函数,它只是改变了事件的类型。

提前谢谢你。

最佳答案

我修复了这两行以获得预期的结果:

"   Type: " + elem.target.nodeName +
"\n Id: " + elem.target.getAttribute("id") +

希望对您有所帮助

document.getElementsByTagName("body")[0].addEventListener("click", function() {
print(event);
}, false);
document.getElementsByTagName("div")[0].addEventListener("click", function() {
print(event);
}, false);
document.getElementsByTagName("div")[1].addEventListener("click", function() {
print(event);
}, false);
document.getElementsByTagName("input")[0].addEventListener("click", function() {
print(event);
}, false);

document.getElementsByTagName("div")[2].addEventListener("mouseout", function() {
print(event);
}, false);
document.getElementsByTagName("input")[1].addEventListener("mouseout", function() {
print(event);
}, false);

function print(elem) {
alert("JavaScript alert\n\n" +
"Element\n" +
" Type: " + elem.target.nodeName +
"\n Id: " + elem.target.getAttribute("id") +
"\nEvent's name: " + elem.type +
"\nMouse's coordinates" +
"\n Screen: " + elem.screenX + ", " + elem.screenY +
"\n Window: " + elem.clientX + ", " + elem.clientY +
"\n HTML item: " + elem.offsetX + ", " + elem.offsetY);
}
#layer1 {
width: 370px;
height: 220px;
background-color: yellow;
}

#layer2 {
position: relative;
width: 130px;
height: 47px;
top: 10px;
left: 10px;
background-color: #CC0066;
}

#layer3 {
position: relative;
width: 200px;
height: 100px;
top: 10px;
left: 150px;
background-color: #334466;
}

#button1 {
position: relative;
top: 4px;
left: 4px;
}

#button2 {
position: relative;
top: 4px;
left: 4px;
}
<html>

<head>

<body>
<div id="layer1">
<div id="layer2">
<input type="submit" id="button1" value="Button 1 (onclick)"></input>
</div>
<div id="layer3">
<input type="submit" id="button2" value="Button 2 (onmouseout)"></input>
</div>
</div>
</body>

</html>

关于JavaScript - 事件 relatedTarget 不适用于 onClick,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52690453/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com