动画边框

时间:2012-10-03 10:39:52

标签: javascript jquery html css

我有这个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”类,您可以看到该工作class“current_item”是添加顶部和底部边框并且效果很好,但我想在鼠标悬停或鼠标移动时在边框或类“current_item”中添加一些动画。

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

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

3 个答案:

答案 0 :(得分:1)

你能不能add the following.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;

答案 1 :(得分:0)

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

 $('#currentitem').hover(function(){
        (this).animate({borderColor:'#fff'});
    }, function(){
       (this).animate({borderColor:'#000'});
    });

答案 2 :(得分: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 ;
}