1

我有这个 jquery 代码。

//this is the main javascript

$(document).ready(function(){

    $('nav.menu a').hover(
        function () {
            $('nav.menu').find(".current_item").removeClass("current_item");
            $(this).addClass("current_item");

        }, 
        function () {
            $(this).removeClass("current_item");
            $('nav.menu').find(".damenu").addClass("current_item")
        }
);

});

和这个 html 结构

<nav class="menu">
    <a href="home.html" class="current_item damenu">Home</a>
    <a href="gallery.html">Gallery</a>
    <a href="home.html">Portfolio</a>
    <a href="home.html">About</a>
    <a href="home.html">Contact</a>
</nav>

这个CSS

.menu
{
background: 1px solid #00ffff;
width: 100%;
padding: 0px 0px 0px 10px;
}
.menu a
{
padding: 8px;
color: #0099ff;
font: bold 20px Archivo Narrow, Arial Rounded MT, Tahoma, Calibri, Asap, Arial,     Verdana, sans-serif;
text-decoration: none;
float: left;
margin-right: 8px;
text-shadow: 2px 1px 1px #ffffff;
border-top: 3px solid transparent;
border-bottom: 3px solid transparent;
}
.current_item /*, .menu a:hover*/
{
color: #C5F700 !important;
border-top: 3px solid #C5F700 !important;
border-bottom: 3px solid #C5F700 !important;
}

如您所见,例程是这样的,当前菜单有一个类,每当用户将鼠标悬停在其中一个菜单上时,当前菜单的类就会被删除,并且“current_item”类会添加到当前悬停菜单中,并且在 mouseout 事件中,“current_item”类从当前悬停元素中删除,“current_item”类被添加回当前菜单,该菜单也有“damenu”类,您可以看到“current_item”类的工作“是添加顶部和底部边框,效果很好,但我想在鼠标悬停或鼠标悬停时在边框或“current_item”类中添加一些动画。

准确地说,我想在鼠标悬停或鼠标悬停事件中为边框或“current_item”类设置动画,而且,无论如何我可以将导航设置为中心吗?

我是开放的,想法,建议和建议。希望这里有人可以帮忙,谢谢。

4

3 回答 3

1

你不能只添加以下内容.current_item

-webkit-transition: .5s border-color, color ease;
-moz-transition: .5s border-color, color ease;
-ms-transition: .5s border-color, color ease;
-o-transition: .5s border-color, color ease;
transition: .5s border-color, color, ease;
于 2012-10-03T10:47:43.637 回答
0

获取 JQuery 颜色动画插件,然后:

 $('#currentitem').hover(function(){
        (this).animate({borderColor:'#fff'});
    }, function(){
       (this).animate({borderColor:'#000'});
    });
于 2012-10-03T10:48:21.993 回答
0

您可以仅通过 css 为边框设置动画

.menu
{
background: 1px solid #00ffff;
width: 100%;
padding: 0px 0px 0px 10px;
}
.menu a
{
padding: 8px;
color: #0099ff;
font: bold 20px Archivo Narrow, Arial Rounded MT, Tahoma, Calibri, Asap, Arial,     Verdana, sans-serif;
text-decoration: none;
float: left;
margin-right: 8px;
text-shadow: 2px 1px 1px #ffffff;
border-top: 3px solid transparent;
border-bottom: 3px solid transparent;
-webkit-transition: 1s all ease;
-moz-transition: 1s all ease;
-ms-transition: 1s all ease;
-o-transition: 1s all ease;
transition: 1s all ease;
}
.menu a.current_item, .menu a:hover
{
color: #C5F700 !important;
border-top: 3px solid #C5F700 ;
border-bottom: 3px solid #C5F700 ;
}
于 2012-10-03T11:42:00.437 回答