re2.addEventListener("mouseover", function(){ const re21 = document.getElementById("reso"); re21.style.position = "absolute"; re21.style.top = "50%"; re21.style.left = "50%"; console.log("Exiting Listener- mouseOver"); re3.addEventListener("mouseover", function(){ const re22 = document.getElementById("reso"); re22.style.position = "fixed"; re22.style.top ="0px"; re22.style.left="0px"; console.log("Exiting Listener- mouseout"); }); });
Ich habe ein HTML-Div-Element mit der ID „reso“. Ich möchte das Element immer dann von Punkt A nach Punkt B verschieben, wenn die Maus es erreicht. Wie können wir das machen?
Wenn wir den obigen Javascript-Code ausführen. Es bewegt sich nur einmal. Anschließend haben wir versucht, den obigen Code zusammen mit einigen Konsolenprotokollen zu verpacken, indem wir eine Schleife von i=0 bis 10 verwendeten. Alle Protokolle werden gedruckt. Der Ereignis-Listener wird jedoch immer noch nur einmal ausgeführt.
Können Sie uns dabei helfen?
您可能需要在事件回调函数之外的外部范围内初始化一个计数器,然后在每次触发事件时递增它。
您可以使用 mousemove 事件代替 mouseover 事件。这将允许您随着鼠标移动不断更新元素的位置