jQuery实现级联菜单效果(仿淘宝首页菜单动画)


Posted in Javascript onApril 10, 2014

相信初学HTM+DIV+CSSl的同学们肯定也想做出淘宝网首页的菜单动画吧。今天我们就带大家体会一下级联菜单的显示。小编我只是实现了简单地效果,不过总体来说原理是一样的哦,那么先让大家看看效果图吧。

那么要实现这个效果我们当然要使用到的是jQuery,那么我就开始讲解怎么做的了,先上html和css的代码

<!DOCTYPE html> 
<html> 
<head> 
<title>menu.html</title> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> 
<meta http-equiv="description" content="this is my page"> 
<meta http-equiv="content-type" content="text/html; charset=UTF-8"> 
<link rel="stylesheet" type="text/css" href="../css/menu.css"> 
<script type="text/javascript" src="../js/jquery-1.10.2.js"></script> 
<script type="text/javascript" src="../js/menu.js"></script> 
</head> 
<body> 
<ul> 
<li class="menu"> 
<div class="title"> 
<span>电脑数码类产品</span> 
</div> 
<ul class="content"> 
<li class="optn"><a href="#">笔记本</a> 
<ul class="tip"> 
<li><a href="#">笔记本1</a></li> 
<li><a href="#">笔记本1</a></li> 
<li><a href="#">笔记本1</a></li> 
<li><a href="#">笔记本1</a></li> 
</ul> 
</li> 
<li class="optn"><a href="#">移动硬盘</a> 
<ul class="tip"> 
<li><a href="#">移动硬盘1</a></li> 
<li><a href="#">移动硬盘1</a></li> 
<li><a href="#">移动硬盘1</a></li> 
<li><a href="#">移动硬盘1</a></li> 
</ul> 
</li> 
<li class="optn"><a href="#">电脑软件</a> 
<ul class="tip"> 
<li><a href="#">电脑软件1</a></li> 
<li><a href="#">电脑软件1</a></li> 
<li><a href="#">电脑软件1</a></li> 
<li><a href="#">电脑软件1</a></li> 
</ul> 
</li> 
<li class="optn"><a href="#">数码产品</a> 
<ul class="tip"> 
<li><a href="#">数码产品1</a></li> 
<li><a href="#">数码产品1</a></li> 
<li><a href="#">数码产品1</a></li> 
<li><a href="#">数码产品1</a></li> 
</ul> 
</li> 
</ul> 
</li> 
</ul> 
</body> 
</html>

menu.css
@CHARSET "UTF-8"; *{ 
margin: 0px; 
padding: 0px; 
} 
ul,li{ 
list-style-type: none; 
} 
.menu{ 
width: 190px; 
border: 1px red solid; 
background-color: #fffdd2; 
} 
.optn{ 
width: 190px; 
line-height: 28px; 
border-top: 1px red dashed; 
} 

.content{ 
padding-top:10px; 
clear: left; 
} 

a{ 
text-decoration: none; 
color: #666; 
padding: 10px; 
} 
.optnFocus{ 
background-color: #fff; 
font-weight: bold; 
} 
div{ 
padding: 10px; 
} 
.tip{ 
width: 190px; 
border: 2px red solid; 
position: absolute; 
background-color: #fff; 
display: none; 
} 
.tip li{ 
line-height: 23px; 
}

接下来就是主要的jquery代码:menu.js
$(function(){ var curY;//获取所选想的TOP 
var curH;//获取所选的Height 
var curW;//获取所选的width 
var objL;//获取当前对象 
//自定义函数用于获取当前位置 
function setInitValue(obj){ 
curY=obj.offset().top; 
curH=obj.height(); 
curW=obj.width(); 
} 
//设置当前所选项的鼠标滑动事件 
$(".optn").mouseover(function(){ 
objL=$(this);//获取当前对象 
setInitValue(objL); 
var allY=curY-curH +"px"; 
objL.addClass("optnFocus"); 
//获取气元素下的下一个ul 
$(".tip",this).show().css({"top":allY,"left":curW});; 
}); 
$(".optn").mouseout(function(){ 
$(this).removeClass("optnFocus"); 
$(".tip",this).hide(); 
}); 
//为了防止移到子菜单时子菜单不见,我们也要为子菜单设置鼠标事件 
$(".tip").mouseover(function(){ 
$(this).show(); 
objL=$(this).prev("li"); 
setInitValue(objL); 
objL.addClass("optnFocus"); 
}); 
$(".tip").mouseout(function(){ 
$(this).hide(); 
$(this).prev("li").removeClass("optnFocus"); 
}); 
});

注意要点:

1.由于我们用的是较高版本的jquery文件库,所以有些方法是不支持的,例如获取下一个元素的第一个子元素next(erp),在10.1中是不支持的,所以我换了一种方法$(chiled,select),表示在select的范围进行元素的选择

2.整个效果的实现我们还要为子选项框绑定鼠标事件,目的就是为了不在我们移动到子选项卡中,突然消失。

要实现好看的效果就需要加一些图片和样式,不过原理是一样的哦

Javascript 相关文章推荐
jquery实现显示已选用户
Jul 21 Javascript
浅谈javascript中onbeforeunload与onunload事件
Dec 10 Javascript
JavaScript文档碎片操作实例分析
Dec 12 Javascript
常见的javascript跨域通信方法
Dec 31 Javascript
javascript对象的创建和访问
Mar 08 Javascript
AngularJS实践之使用ng-repeat中$index的注意点
Dec 22 Javascript
三种方式实现瀑布流布局
Feb 10 Javascript
JS的函数调用栈stack size的计算方法
Jun 24 Javascript
Vue将页面导出为图片或者PDF
Aug 17 Javascript
利用js-cookie实现前端设置缓存数据定时失效
Jun 18 Javascript
JS实现简易图片自动轮播
Oct 16 Javascript
vue 如何使用递归组件
Oct 23 Javascript
js获取视频时长代码
Apr 10 #Javascript
js转化毫秒为时间格式代码
Apr 10 #Javascript
jquery移除、绑定、触发元素事件使用示例详解
Apr 10 #Javascript
jquery序列化表单去除指定元素示例代码
Apr 10 #Javascript
jquery删除ID为sNews的tr元素的内容
Apr 10 #Javascript
javascript正则匹配汉字、数字、字母、下划线
Apr 10 #Javascript
jquery禁止输入数字以外的字符的示例(纯数字验证码)
Apr 10 #Javascript
You might like
php上传文件,创建递归目录的实例代码
2013/10/18 PHP
PHP中实现接收多个name相同但Value不相同表单数据实例
2015/02/03 PHP
php中switch语句用法详解
2015/08/17 PHP
学习php设计模式 php实现适配器模式
2015/12/07 PHP
PHP遍历目录文件的常用方法小结
2017/02/03 PHP
formValidator3.3的ajaxValidator一些异常分析
2011/07/12 Javascript
Chosen 基于jquery的选择框插件使用方法
2012/05/30 Javascript
node.js中的http.response.setHeader方法使用说明
2014/12/14 Javascript
javascript+html5实现绘制圆环的方法
2015/07/28 Javascript
JavaScript修改作用域外变量的方法
2016/03/25 Javascript
JavaScript数组方法总结分析
2016/05/06 Javascript
BootStrap中Datetimepicker和uploadify插件应用实例小结
2016/05/26 Javascript
BootStrap 标题设置跨行无效的解决方法
2017/10/25 Javascript
在Vue中使用echarts的方法
2018/02/05 Javascript
webpack公共组件引用路径简化小技巧
2018/06/15 Javascript
javascript和php使用ajax通信传递JSON的实例
2018/08/21 Javascript
JS实现的简单分页功能示例
2018/08/23 Javascript
axios+Vue实现上传文件显示进度功能
2019/04/14 Javascript
送你43道JS面试题(收藏)
2019/06/17 Javascript
Element ui 下拉多选时新增一个选择所有的选项
2019/08/21 Javascript
小程序实现长按保存图片的方法
2019/12/31 Javascript
微信小程序8种数据通信的方式小结
2020/02/03 Javascript
[01:13]2014DOTA2西雅图邀请赛 舌尖上的TI4
2014/07/08 DOTA
基于Python实现的百度贴吧网络爬虫实例
2015/04/17 Python
python实现在字符串中查找子字符串的方法
2015/07/11 Python
python实现学生信息管理系统
2020/04/05 Python
PyQt5+requests实现车票查询工具
2019/01/21 Python
Python Socketserver实现FTP文件上传下载代码实例
2020/03/27 Python
html5-websocket基于远程方法调用的数据交互实现
2012/12/04 HTML / CSS
超市开店计划书
2014/04/26 职场文书
应届大学生自荐书
2014/06/17 职场文书
大学生就业协议书范本(适用于公司企业)
2014/10/07 职场文书
上甘岭观后感
2015/06/10 职场文书
校长新学期寄语2016
2015/12/04 职场文书
PHP中strval()函数实例用法
2021/06/07 PHP
Python将CSV文件转化为HTML文件的操作方法
2021/06/30 Python