html 菜单切换效果,基于jQuery实现的菜单切换效果

这是一个非常流畅的菜单展示效果,应用在亚马逊上,当你上下移动鼠标的时候,二级菜单会非常轻快的切换,没有任何延时,给用户如滑丝般的感觉。这种效果借助于一款jQuery插件menu-aim,本文将结合实例讲解如何实现速度超快的菜单效果。

769f80683ceb3c511bfa5332797147b8.png

HTML

首先建立主菜单,我们借用电商网站常见的商品分类。其html结构代码如下,其中我们用到了html5的data-submenu-id属性设置,这在插件调用时非常有用。

子菜单与主菜单对应,每一个子菜单的id属性值必须与主菜单的data-submenu-id属性值对应,子菜单内容可以为任意html标签代码,p,img,audio都可以,格式如下:

CSS

我们将主菜单dropdown-menu位置固定,子菜单popover默认隐藏,通过css3技术可以设置菜单阴影圆角效果,子菜单内容的css可以根据需要自由发挥。

.active{position:relative}

.dropdown-menu { position: absolute;

z-index: 1000;float: left;

min-width: 120px;padding: 5px 0;margin: 2px 0 0;list-style: none;

background-color: #ffffff;border: 1px solid #ccc;

-webkit-border-radius: 6px;-moz-border-radius: 6px;border-radius: 6px;

-webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);-moz-box-shadow: 0 5px 10px

rgba(0, 0, 0, 0.2);box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);

}

.dropdown-menu li{height:24px; line-height:24px; text-align:center}

.dropdown-menu li a{display:block}

.dropdown-menu li a:hover{color:#fff; text-decoration:none; background:#39f}

.popover {

position: absolute;top: 0;left: 0; z-index: 1010;display: none;

width: 320px;-webkit-border-radius: 6px;-moz-border-radius: 6px;border-radius: 6px;

-webkit-border-top-left-radius: 0px;-webkit-border-bottom-left-radius: 0px;

border-top-left-radius: 0px;border-bottom-left-radius: 0px;overflow: hidden;

padding: 1px 1px 1px 15px;text-align: left;white-space: normal;

background-color: #fff;border: 1px solid #ccc;

border: 1px solid rgba(0, 0, 0, 0.2);

webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);-moz-box-shadow: 0 5px 10px

rgba(0, 0, 0, 0.2);box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);

}

jQuery

下面我们隆重推出jquery.menu-aim.js,该插件是一款基于jQuery的菜单插件,插件作者关注了用户体验并精于算法,根据鼠标轨迹,将菜单切换效果实现得淋漓精致,该插件“超快”的反应效果是不是让我们有中“超爽”的感觉?插件地址:

使用$(element).menuAim()调用jquery.menu-aim.js,当鼠标触发主菜单时调用自定义函数activateSubmenu(),当离开主菜单时调用自定义函数deactivateSubmenu()。

$(function(){

$(".dropdown-menu").menuAim({

activate: activateSubmenu,//触发主菜单,显示子菜单

deactivate: deactivateSubmenu //离开主菜单,隐藏子菜单

});

});

如上调用就可以完成子菜单间的快速切换,jquery.menu-aim.js还提供其他几种方法,enter()和exit(),都是控制鼠标移入移出、调用函数等。

接下来,我们写上自定义函数

var $menu = $(".dropdown-menu");

function activateSubmenu(row) {

var $row = $(row),

submenuId = $row.data("submenuId"),

$submenu = $("#" + submenuId),

offset = $menu.offset(),

height = $menu.outerHeight(),

width = $menu.outerWidth();

$submenu.css({ //设置子菜单样式

display: "block", //显示子菜单

top: offset.top,

left: offset.left + width - 5,

height: height - 4

});

//设置主菜单样式(鼠标滑向主菜单时)

$row.find("a").addClass("maintainHover");

}

function deactivateSubmenu(row) {

var $row = $(row),

submenuId = $row.data("submenuId"),

$submenu = $("#" + submenuId);

$submenu.css("display", "none"); //隐藏子菜单

$row.find("a").removeClass("maintainHover");恢复主菜单样式

}

怎么样,你也可以做一个amazon.cn式的菜单效果了,以上就是本文的全部内容,希望本文对大家学习jquery有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值