最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Adding eventlisteners to if statement - Stack Overflow

programmeradmin1浏览0评论

I am wondering if you can add onmouseover + onmouseout to an if/else statement in Javascript for example:

function pan() {
        var ID = document.getElementById("grad");
        var change = ID.style.backgroundSize = "1200px 500px";
        var revert = ID.style.backgroundSize = "1080px 300px";

        if (){
            change.addEventListener("onmouseover");
        }else {
            revert.addEventListener("onmouseout");
        }

    }

I have looked everywhere and cannot see a definite yes or no, unless its in jQuery, and I haven't even looked at jQuery yet so please don't give an answer in jQuery.

If, it is possible, how do you do it?

Else, whats the alternative?

I am wondering if you can add onmouseover + onmouseout to an if/else statement in Javascript for example:

function pan() {
        var ID = document.getElementById("grad");
        var change = ID.style.backgroundSize = "1200px 500px";
        var revert = ID.style.backgroundSize = "1080px 300px";

        if (){
            change.addEventListener("onmouseover");
        }else {
            revert.addEventListener("onmouseout");
        }

    }

I have looked everywhere and cannot see a definite yes or no, unless its in jQuery, and I haven't even looked at jQuery yet so please don't give an answer in jQuery.

If, it is possible, how do you do it?

Else, whats the alternative?

Share Improve this question edited Sep 4, 2021 at 8:37 Brian Tompsett - 汤莱恩 5,89372 gold badges61 silver badges133 bronze badges asked Sep 1, 2016 at 5:19 RickyRicky 7913 gold badges8 silver badges30 bronze badges
Add a ment  | 

1 Answer 1

Reset to default 2

It is possible, but your code is not correct, here the corrected code:

     function pan() {
        var ID = document.getElementById("grad");
        var change = ID.style.backgroundColor = "red";
        var revert = ID.style.backgroundColor = "black";

        if( true){
            ID.addEventListener("mouseover", function(){alert("EVENT OVER")});
        }else {
            ID.addEventListener("mouseout", function(){alert("EVENT OUt")});
        }
    }

You just can bind Events on elements.

Here is some documentation to the addEventListener function https://developer.mozilla/en-US/docs/Web/API/EventTarget/addEventListener

But I assume you would want to do something like this (I use backgroundColor, so the example can be seen better):

var ID = document.getElementById("grad");

function change (event){
  event.target.style.backgroundColor = "red";
}

function revert (event){
  event.target.style.backgroundColor = "white";
}

ID.addEventListener("mouseover", change);
ID.addEventListener("mouseout", revert);
<div id="grad" style="border:1px solid black">sdfgsdfg</div>

发布评论

评论列表(0)

  1. 暂无评论