如何使用eventListener为导航菜单,多个列表项创建javascript悬停效果?

时间:2013-03-17 01:47:59

标签: javascript for-loop hover addeventlistener

我想在循环中使用2个addEventListeners来添加和删除导航菜单中的悬停类。

这是CSS和HTML:                    .hovering {background-color:yellow; }         

<ul>
    <li><a href="index.html" id="homeId">One</a></li>
    <li><a href="businesspage.html" id="businessId">Two</a></li>
    <li><a href="newspage.html" id="newsId">Three</a></li>  
</ul>

这是可行的JavaScript,但没有使用循环:

/* Script 1 start */
// First item
var homePg = document.getElementById("homeId"); // The homeID is in the <a> element
var homeHover = {
    addHoverClass: function() {
        homePg.setAttribute("class", "hovering");
    },
    removeHoverClass: function() {
        homePg.removeAttribute("class");
    }
} //End homeHover object
// Activate focus event on menu 
homePg.addEventListener("mouseover", homeHover.addHoverClass, false);
homePg.addEventListener("mouseout", homeHover.removeHoverClass, false);

// Second item

var businessPg = document.getElementById("businessId");
var businessHover = {
    addHoverClass: function() {
        businessPg.setAttribute("class", "hovering");
    },
    removeHoverClass: function() {
        businessPg.removeAttribute("class");
    }

} //End hovMenu object
// Activate focus event on menu 
businessPg.addEventListener("mouseover", businessHover.addHoverClass, false);
businessPg.addEventListener("mouseout", businessHover.removeHoverClass, false);

//Third item

    var newsPg = document.getElementById("newsId");
    var newsHover = {
        addHoverClass: function() {
            newsPg.setAttribute("class", "hovering");
        },
        removeHoverClass: function() {
            newsPg.removeAttribute("class");
        }

    } //End hovMenu object
    // Activate focus event on menu 
    newsPg.addEventListener("mouseover", newsHover.addHoverClass, false);
    newsPg.addEventListener("mouseout", newsHover.removeHoverClass, false);


 /* End Script 1 */

当我使用脚本2时,只有最后一项正确地悬停。任何帮助表示赞赏。感谢

 /* Script 2 start */
var gbotNav = [ "homePg", "businessPg", "newsPg" ];
var gbotId = [ "homeId", "businessId", "newsId" ];
var gbotHov = [ "homeHover", "businessHover", "newsHover"];
var count = gbotNav.length;

for (var i = 0; i < count; i = i + 1) {
var myGbotNav = gbotNav[i];
var myGbotHov = gbotHov[i];
var myGbotId = gbotId[i];

var myGbotNav = document.getElementById( myGbotId );
var myGbotHov = {
        addHoverClass: function() {
            myGbotNav.setAttribute("class", "hovering");
        },
        removeHoverClass: function() {
            myGbotNav.removeAttribute("class");
        }
    } //End gbotHov object
// Activate focus event on menu 
myGbotNav.addEventListener("mouseover", myGbotHov.addHoverClass, false);
myGbotNav.addEventListener("mouseout", myGbotHov.removeHoverClass, false);

} /* End for loop */
/* End Script 2 */

1 个答案:

答案 0 :(得分:0)

您是否尝试过使用CSS:hover伪类?

http://www.w3schools.com/cssref/sel_hover.asp