jQuery渐变发光导航菜单的实例代码

时间:2024-04-09 19:47:36 

jQuery渐变发光导航菜单的实例代码

jQuery渐变发光导航菜单的实例代码

下面和大家分享一下具体的实现过程。

HTML标签结构:


<ul class="animation_menu">
     <li class="current">
         <a href="#">菜单一<span>菜单一</span></a>
     </li>
     <li>
         <a href="#">菜单二<span>菜单二</span></a>
     </li>
     <li>
         <a href="#">菜单三<span>菜单三</span></a>
     </li>
     <li>
         <a href="#">菜单四<span>菜单四</span></a>
     </li>
 </ul>

CSS样式:
li的样式:


.animation_menu li{
    /*块状模式显示,并使其水平平铺显示*/
    display:block;
    float: left;

    /*宽高是背景图片的*/
    width: 111px;
    height: 50px;

    /*设置文字垂直水平居中*/
    line-height: 50px;
    text-align: center;

    font-weight: bold;
    font-size: 18px;
    list-style-type:none;
}

初始看到的a的样式:


.animation_menu li a {
    /*这里是我们背景图片*/
    background-image: url("images/bg-sprite-topmenu.png");
    background-repeat: no-repeat;

    /*设置position属性是为了里面的span能够以a为基准进行定位*/
    position: relative;

    display: block;

    /*我们不使用纯黑色*/
    color: #292724;
    text-decoration:none;
}

hover后看到的span的样式:


.animation_menu li a span {
    /*这里是我们背景图片*/
    background-image: url("images/bg-sprite-topmenu.png");
    background-repeat: no-repeat;

    /*设置块模式显示,并制定宽高和a的宽高一样,和绝对位置,这是为了使其和a里面的文字重合显示*/
    display: block;
    height: 50px;
    width: 111px;
    text-align: center;
    position: absolute;
    top: 0;
    left: 0;

    color:#FFE2BB;
}

用sprite技术定位,a和span各种状态的样式:


/*正常状态下的样式*/
.animation_menu li a {
    /*一般灰色背景*/
    background-position: 0 -153px;
}
    /*hover蓝色高亮背景*/
    .animation_menu li a span {
        background-position: 0 -102px;
    }

/*链接激活状态下的样式*/
.animation_menu li.current a {
     /*一般灰色高亮背景*/
    background-position: 0 0;
}
    /*hover黄色高亮背景*/
    .animation_menu li.current a span {
        background-position: 0 -51px;
    }

css的工作到此就结束了,下面我们来看看javascript。

最后是JavaScript
菜单的渐变效果主要是通过控制opacity实现的,请看下面代码。


// 通过将opacity设置为0,将span的样式和文字隐藏起来
$(".animation_menu li a span").css("opacity", "0");

// 绑定hover事件
$(".animation_menu li a span").hover(
    //mouse on事件
    function () {
        // 通过动态的改变opacity从0到1,这样span的样式和文字就会慢慢的显示出来,覆盖a的样式
        $(this).stop().animate({
            opacity: 1
        }, "slow");
    },
    //mouse out事件
    function () {
        // 当鼠标移走的时候,动态改变为0,这样span又看不见了,看到原来的a的样式了。
        $(this).stop().animate({
            opacity: 0
        }, "slow");
    }
);

//绑定click事件,点击当前连接,为li添加current class,同时移除其他li的current class
$(".animation_menu li a").click(function () {
    $(".animation_menu li a").each(function (index, item) {
        $(item).parent().removeClass("current");
    });
    $(this).parent().addClass("current");
});

到此全部结束,希望这个jQuery导航菜单能够给你一些灵感。

标签:jQuery,渐变,导航菜单
0
投稿

猜你喜欢

  • python计算机视觉opencv卡号识别示例详解

    2023-04-14 13:58:25
  • SQL查询中出现笛卡尔积现象的解决方法

    2024-01-13 04:16:49
  • Python类中self参数用法详解

    2023-06-19 00:40:54
  • DreamweaverMX2004技巧两则

    2010-09-05 21:10:00
  • python 字符串和整数的转换方法

    2023-10-11 02:31:42
  • Python OpenCV招商银行信用卡卡号识别的方法

    2022-01-16 06:31:30
  • django 删除数据库表后重新同步的方法

    2024-01-12 23:11:56
  • 在asp中用集合成批操作数据库

    2008-03-10 17:22:00
  • mysql中json_extract的使用方法实例详解

    2024-01-19 04:28:04
  • SQLServer 附加数据库后出现只读或失败的解决方法

    2024-01-18 11:29:23
  • Python 16进制与中文相互转换的实现方法

    2023-10-03 15:58:35
  • Python中logging日志库实例详解

    2023-10-04 13:26:25
  • Python用内置模块来构建REST服务与RPC服务实战

    2023-05-09 19:32:16
  • oracle 查询表名以及表的列名

    2009-07-26 09:33:00
  • Python批量处理图片大小尺寸方法详解

    2021-12-11 23:12:07
  • Windows Server 2019 MySQL数据库的安装与配置理论+远程连接篇

    2024-01-18 21:19:56
  • Django ModelForm操作及验证方式

    2021-04-22 18:11:44
  • Python Django框架实现应用添加logging日志操作示例

    2022-09-17 20:59:52
  • asp datediff 时间相减

    2011-03-25 10:34:00
  • Python基于staticmethod装饰器标示静态方法

    2022-11-07 07:25:11
  • asp之家 网络编程 m.aspxhome.com