jQuery 打造动态下滑菜单实现说明


Posted in Javascript onApril 15, 2010

jQuery的"write less, do more"的特性可谓是家喻户晓,即使没有很丰富JS编程经验的人,也可以通过其提供的API很快学会如何使用,当然,如果您经验丰富,我还是建议您可以理解jQuery各主要函数的实现原理,其他不说了,直接看看如何用它来实现菜单神奇的效果吧。
jQuery 打造动态下滑菜单实现说明
Step1 - HTML结构

看一下菜单的HTML代码,跟平常的菜单代码没有什么区别:

<div id="menu" class="menu"> 
<ul> 
<li><a href="javascript:;">Home</a></li> 
<li><a href="javascript:;">HTML/CSS</a></li> 
<li><a href="javascript:;">JavaScript</a></li> 
<li><a href="javascript:;">Resources</a></li> 
<li><a href="javascript:;">Tutorials</a></li> 
<li><a href="javascript:;">About</a></li> 
</ul> 
</div>

关键在于利用脚本在每个锚点(a元素)中建立几个分隔层,这样就可以在鼠标悬停时分别控制它们产生动画。为此,我们要在DOM加载完成时候修改DOM的结构,使得每个锚点代码变成如下:

<a href="javascript:;"> 
<span class="out">Home</span> 
<span class="bg"></span> 
<span class="over">Home</span> 
</a>

原先的每个锚点中的内容会被附加到两个span元素(.out和.over)里面,另外一个span元素(.bg)为背景图片层。

至于如何修改DOM结构,JS代码将在Step3中讲解。
Step2 - CSS样式

在示例中,展示了两种样式,有使用背景图的和没有使用背景图的(具体查看演示),您也可以自由定制自己的样式,以设计出更炫酷的菜单,这里提供基本的样式和解释:

/* 以下是菜单基本的样式 */ 
.menu ul li { 
float: left; 
/* 菜单子元素的内容超出不可见 */ 
overflow: hidden; 
/* 以下省略部分代码 */ 
} 
.menu ul li a { 
/* 必须是相对定位 */ 
position: relative; 
display: block; 
width: 110px; 
/* 以下省略部分代码 */ 
} 
.menu ul li a span { 
/* 所有层将使用绝对定位 */ 
position: absolute; 
left: 0; 
width: 110px; 
} 
.menu ul li a span.out { 
top: 0px; 
} 
.menu ul li a span.over, 
.menu ul li a span.bg { 
/* 起初.over层和.bg层相对a元素-45px以达到隐藏的效果 */ 
top: -45px; 
} 
/* 以下是使用背景图的示例 */ 
#menu { 
/* 菜单背景 */ 
background:url(bg_menu.gif) scroll 0 -1px repeat-x; 
border:1px solid #CCC; 
} 
#menu ul li a { 
color: #000; 
} 
#menu ul li a span.over { 
color: #FFF; 
} 
#menu ul li span.bg { 

/* 指定高度和背景图 */ 
height: 45px; 
background: url(bg_over.gif) center center no-repeat; 
}

您也可以在自行定制CSS样式,这里还提供了简化版的样式(查看演示)
Step3 - JavaScript代码

首先要做的是,实现Step1中所说的,在DOM加载完成后修改其DOM结构,具体做法如下:

// 把每个a中的内容包含到一个层(span.out)中, 
// 然后再在span.out层后面追加背景图层(span.bg) 
$("#menu li a").wrapInner( '<span class="out"></span>' ) 



 .append( '<span class="bg"></span>' ); 
// 循环为菜单的a每个添加一个层(span.over) 
$("#menu li a").each(function() { 

$( '<span class="over">' + $(this).text() + '</span>' ) 




 .appendTo( this ); 
});

在讲动画代码之前,先看一下动画的过程,如下图所示:
jQuery 打造动态下滑菜单实现说明
在Step1中我们知道DOM加载后,a元素中建立了几个分隔层,在Step2中,CSS样式中,我们设置了span.bg和span.over层的top属性为-45px,因为span元素已设置为绝对定位,它将相对于li a 元素向上-45px,因为li元素内容超出不可见,所以开始时,.bg层和.over层位于空间范围外。

我们要设置的动画过程是,当鼠标悬停时,三个层同时向下移动,span.out层向下移动至移除可见范围,span.over和span.bg移动进入可见区域,设置span.bg速度比span.over速度稍快,错位产生更加效果。

要实现这样动画效果,使用jQuery的.animate()方法很容易就可以实现,以下是JS代码和解释:

$("#menu li a").hover(function() { 
// 鼠标悬停时候被触发的函数 
$(".out",this).stop().animate({'top':'45px'},250);//下滑至隐藏 
$(".over",this).stop().animate({'top':'0px'},250); //下滑至显示 
$(".bg",this).stop().animate({'top':'0px'},120); //下滑至显示 
}, function() { 
// 鼠标移出时候被触发的函数 
$(".out",this).stop().animate({'top':'0px'},250); //上滑至显示 
$(".over",this).stop().animate({'top':'-45px'},250);//上滑至隐藏 
$(".bg",this).stop().animate({'top':'-45px'},120);//上滑至隐藏 
});

总结

以上讲解了如何一步步打造jQuery动态下滑菜单,您可以按部就班自己实现一个,也可以下载源代码修改定制,当然,您有什么好的提议或者有什么问题,都可以给我留言。

 查看最终效果

 jOuery 动态下滑菜单打包下载

PS:本文由维奇总结

Javascript 相关文章推荐
JS实现金额转换(将输入的阿拉伯数字)转换成中文的实现代码
Sep 30 Javascript
javascript 密码框防止用户粘贴和复制的实现代码
Feb 17 Javascript
原生javascript实现拖动元素示例代码
Sep 01 Javascript
JavaScript表单验证实例之验证表单项是否为空
Jan 10 Javascript
基于jQuery实现的幻灯图片切换
Dec 02 Javascript
node.js发送邮件email的方法详解
Jan 06 Javascript
移动端效果之Swiper详解
Oct 09 Javascript
浅谈让你的代码更简短,更整洁,更易读的ES6小技巧
Oct 25 Javascript
vuex页面刷新后数据丢失的方法
Jan 17 Javascript
详解小程序如何避免多次点击,重复触发事件
Apr 08 Javascript
JS实现页面数据懒加载
Feb 13 Javascript
浅谈vue中get请求解决传输数据是数组格式的问题
Aug 03 Javascript
xheditor与validate插件冲突的解决方案
Apr 15 #Javascript
js 获取Listbox选择的值的代码
Apr 15 #Javascript
JavaScript toFixed() 方法
Apr 15 #Javascript
js function定义函数使用心得
Apr 15 #Javascript
combox改进版 页面原型参考dojo的,比网上jQuery的那些combox功能强,代码更小
Apr 15 #Javascript
关于文本框的一些限制控制总结~~
Apr 15 #Javascript
JS input文本框禁用右键和复制粘贴功能的代码
Apr 15 #Javascript
You might like
收音机怀古---春雷3P7图片欣赏
2021/03/02 无线电
discuz Passport 通行证 整合笔记
2008/06/30 PHP
如何阻止网站被恶意反向代理访问(防网站镜像)
2014/03/18 PHP
laravel 输出最后执行sql 附:whereIn的使用方法
2019/10/10 PHP
js 火狐下取本地路径实现思路
2013/04/02 Javascript
jquery easyui combobox模糊过滤(示例代码)
2013/11/30 Javascript
jquery判断元素是否隐藏的多种方法
2014/05/06 Javascript
jQuery中的read和JavaScript中的onload函数的区别
2014/08/27 Javascript
json实现前后台的相互传值详解
2015/01/05 Javascript
深入理解JavaScript系列(25):设计模式之单例模式详解
2015/03/03 Javascript
jQuery对象与DOM对象之间的相互转换
2015/03/03 Javascript
JavaScript通过select动态更换图片的方法
2015/03/23 Javascript
JavaScript跨平台的开源框架NativeScript
2015/03/24 Javascript
javascript实现图片上传前台页面
2015/08/18 Javascript
JS实现的不规则TAB选项卡效果代码
2015/09/18 Javascript
jQuery+Ajax实现无刷新分页
2015/10/30 Javascript
浅谈javascript中new操作符的原理
2016/06/07 Javascript
如何检测JavaScript的各种类型
2016/07/30 Javascript
详解webpack 多页面/入口支持&amp;公共组件单独打包
2017/06/29 Javascript
ReactNative之FlatList的具体使用方法
2017/11/29 Javascript
JavaScript折半查找(二分查找)算法原理与实现方法示例
2018/08/06 Javascript
vue中Axios的封装与API接口的管理详解
2018/08/09 Javascript
vue-cli3 从搭建到优化的详细步骤
2019/01/20 Javascript
vue操作dom元素的3种方法示例
2020/09/20 Javascript
[05:08]DOTA2-DPC中国联赛3月6日Recap集锦
2021/03/11 DOTA
Python标准库内置函数complex介绍
2014/11/25 Python
Python for Informatics 第11章之正则表达式(四)
2016/04/21 Python
Python模糊查询本地文件夹去除文件后缀的实例(7行代码)
2017/11/09 Python
python读取一个目录下所有txt里面的内容方法
2018/06/23 Python
解决Python print输出不换行没空格的问题
2018/11/14 Python
python 通过可变参数计算n个数的乘积方法
2019/06/13 Python
python字典通过值反查键的实现(简洁写法)
2020/09/30 Python
HTML5之SVG 2D入门1—SVG(可缩放矢量图形)概述
2013/01/30 HTML / CSS
教导处工作制度
2014/01/18 职场文书
乡镇务虚会发言材料
2014/10/20 职场文书
2016年三八节红领巾广播稿
2015/12/17 职场文书