gpt4 book ai didi

javascript - 为什么我只点击了一个复选框,却调用了所有复选框的点击事件?

转载 作者:行者123 更新时间:2023-12-02 22:58:04 24 4
gpt4 key购买 nike

我只选中了一个复选框,但附加到其他复选框的另一个单击监听器被调用。我不认为这是事件冒泡的典型案例。我该如何解决这个问题?

我已经检查过这是否与事件冒泡有关。但我不这么认为,因为我的输入标签是水平的。

弹出.html

    <!DOCTYPE html>
<html>
<head>
</head>
<body>
<h3>Input game title to search metacritic score!</h3><br>
<p>Press the "Enter" key inside the input field to trigger the button.</p>
<input id="gameTitle" value="Example : &quot;Gears 5&quot;">
<input type="checkbox" name="Pc" id="pcCheck">PC<br>
<input type="checkbox" name="Ps4" id="ps4Check">PS4<br>
<input type="checkbox" name="Xbox" id="xboxCheck">XBOX<br>
<input type="checkbox" name="Switch" id="switchCheck">SWITCH<br>
<button id="confirmBtn">Confirm</button>
<p id = "content"></p>
<script src="popup.js"></script>
</body>
</html>

Popup.js

var dict = {};
dict["confirmBtn"] = document.getElementById("confirmBtn");
dict["pcCheck"] = document.getElementById("pcCheck");
dict["ps4Check"] = document.getElementById("ps4Check");
dict["xboxCheck"] = document.getElementById("xboxCheck");
dict["switchCheck"] = document.getElementById("switchCheck");

document.addEventListener('DOMContentLoaded', function() {
dict["confirmBtn"].addEventListener("click", confirmBtnEvent);
dict["pcCheck"].addEventListener("click", CheckEvent("pcCheck"),{capture:true});
dict["ps4Check"].addEventListener("click", CheckEvent("ps4Check"),{capture:true});
dict["xboxCheck"].addEventListener("click", CheckEvent("xboxCheck"),{capture:true});
dict["switchCheck"].addEventListener("click", CheckEvent("switchCheck"),{capture:true});
});

我希望在单击相应的复选框时调用一个特定的事件监听器。

最佳答案

您没有正确调用addEventListener。参数应该是函数引用,而不是调用函数的结果。并且这些选项必须是 addEventListener 的参数。

dict["pcCheck"].addEventListener("click", function() {
CheckEvent("pcCheck");
},{capture:true});

但是,如果稍微更改 CheckEvent,则可以将其简化为:

dict["pcCheck"].addEventListener("click", CheckEvent, {capture:true});

当调用事件监听器时,this 被设置为事件的目标,因此您可以只在函数内使用 this,而不是调用 document.getElementById() 带有参数。

关于javascript - 为什么我只点击了一个复选框,却调用了所有复选框的点击事件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57900285/

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