JS+CSS实现大气清新的滑动菜单效果代码


Posted in Javascript onOctober 22, 2015

本文实例讲述了JS+CSS实现大气清新的滑动菜单效果代码。分享给大家供大家参考,具体如下:

这是一款比较大气清新的滑动导航菜单,CSS和JavaScript配合完成,鼠标放到一级菜单上,会滑出二级的菜单,兼容性也不错,适合大多数网站使用,用到两张背景图片,请拷贝图片地址下载图片。

运行效果截图如下:

JS+CSS实现大气清新的滑动菜单效果代码

在线演示地址如下:

具体代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>滑动导航菜单</title>
<style>
body {margin:25px; font:12px Verdana, Arial, Helvetica}
* {padding:0; margin:0}
.dropdown {float:left; padding-right:5px}
.dropdown dt {width:188px; border:2px solid #9ac1c9; padding:8px; font-weight:bold; cursor:pointer; background:url(images/header.gif)}
.dropdown dt:hover {background:url(images/header_over.gif)}
.dropdown dd {position:absolute; overflow:hidden; width:208px; display:none; background:#fff; z-index:200; opacity:0}
.dropdown ul {width:204px; border:2px solid #9ac1c9; list-style:none; border-top:none}
.dropdown li {display:inline}
.dropdown a, .dropdown a:active, .dropdown a:visited {display:block; padding:5px; color:#333; text-decoration:none; background:#eaf0f2; width:194px}
.dropdown a:hover {background:#d9e1e4; color:#000}
.dropdown .underline {border-bottom:1px solid #b9d6dc}
</style>
<script type="text/javascript">
var DDSPEED = 10;
var DDTIMER = 15;
function ddMenu(id,d){
 var h = document.getElementById(id + '-ddheader');
 var c = document.getElementById(id + '-ddcontent');
 clearInterval(c.timer);
 if(d == 1){
  clearTimeout(h.timer);
  if(c.maxh && c.maxh <= c.offsetHeight){return}
  else if(!c.maxh){
   c.style.display = 'block';
   c.style.height = 'auto';
   c.maxh = c.offsetHeight;
   c.style.height = '0px';
  }
  c.timer = setInterval(function(){ddSlide(c,1)},DDTIMER);
 }else{
  h.timer = setTimeout(function(){ddCollapse(c)},50);
 }
}
function ddCollapse(c){
 c.timer = setInterval(function(){ddSlide(c,-1)},DDTIMER);
}
function cancelHide(id){
 var h = document.getElementById(id + '-ddheader');
 var c = document.getElementById(id + '-ddcontent');
 clearTimeout(h.timer);
 clearInterval(c.timer);
 if(c.offsetHeight < c.maxh){
  c.timer = setInterval(function(){ddSlide(c,1)},DDTIMER);
 }
}
function ddSlide(c,d){
 var currh = c.offsetHeight;
 var dist;
 if(d == 1){
  dist = (Math.round((c.maxh - currh) / DDSPEED));
 }else{
  dist = (Math.round(currh / DDSPEED));
 }
 if(dist <= 1 && d == 1){
  dist = 1;
 }
 c.style.height = currh + (dist * d) + 'px';
 c.style.opacity = currh / c.maxh;
 c.style.filter = 'alpha(opacity=' + (currh * 100 / c.maxh) + ')';
 if((currh < 2 && d != 1) || (currh > (c.maxh - 2) && d == 1)){
  clearInterval(c.timer);
 }
}
</script>
</head>
<body>
<dl class="dropdown">
 <dt id="one-ddheader" onmouseover="ddMenu('one',1)" onmouseout="ddMenu('one',-1)">源码下载</dt>
 <dd id="one-ddcontent" onmouseover="cancelHide('one')" onmouseout="ddMenu('one',-1)">
  <ul>
   <li><a href="#" class="underline">最新源码</a></li>
   <li><a href="#" class="underline">下载排行</a></li>
   <li><a href="#" class="underline">脚本资源</a></li>
   <li><a href="#">Ajax实例</a></li>
  </ul>
 </dd>
</dl>
<dl class="dropdown">
 <dt id="two-ddheader" onmouseover="ddMenu('two',1)" onmouseout="ddMenu('two',-1)">网页特效</dt>
 <dd id="two-ddcontent" onmouseover="cancelHide('two')" onmouseout="ddMenu('two',-1)">
  <ul>
   <li><a href="#" class="underline">菜单导航</a></li>
   <li><a href="#" class="underline">层和布局</a></li>
   <li><a href="#" class="underline">图片特效</a></li>
  </ul>
 </dd>
</dl>
</body>
</html>

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
使Ext的Template可以解析二层的json数据的方法
Dec 22 Javascript
理解Javascript_05_原型继承原理
Oct 13 Javascript
jQuery实现的感应鼠标悬停图片色彩渐显效果
Mar 03 Javascript
jquery 插件实现瀑布流图片展示实例
Apr 03 Javascript
浅析Bootstrap验证控件的使用
Jun 23 Javascript
bootstrap基础知识学习笔记
Nov 02 Javascript
正则 js分转元带千分符号详解
Mar 08 Javascript
详解ECMAScript6入门--Class对象
Apr 27 Javascript
vue component组件使用方法详解
Jul 14 Javascript
简单快速的实现js计算器功能
Aug 17 Javascript
微信小程序实现Swiper轮播图效果
Nov 22 Javascript
微信小程序地图实现展示线路
Jul 29 Javascript
Webpack 实现 Node.js 代码热替换
Oct 22 #Javascript
JS+CSS实现仿msn风格选项卡效果代码
Oct 22 #Javascript
Node.js巧妙实现Web应用代码热更新
Oct 22 #Javascript
深入剖析JavaScript编程中的对象概念
Oct 21 #Javascript
JavaScript中Boolean对象的属性解析
Oct 21 #Javascript
深入解析JavaScript中的数字对象与字符串对象
Oct 21 #Javascript
jQuery无刷新切换主题皮肤实例讲解
Oct 21 #Javascript
You might like
浅析PHP数据导出知识点
2018/02/17 PHP
Javascript实现的分页函数
2006/12/22 Javascript
asp.net和asp下ACCESS的参数化查询
2008/06/11 Javascript
锋利的jQuery jQuery中的DOM操作
2010/03/21 Javascript
js中的eventType事件及其浏览器支持性介绍
2013/11/29 Javascript
nodejs基础知识
2017/02/03 NodeJs
vue.js开发环境安装教程
2017/03/17 Javascript
一个Js文件函数中调用另一个Js文件函数的方法演示
2017/08/14 Javascript
JavaScript实现的DOM树遍历方法详解【二叉DOM树、多叉DOM树】
2018/05/07 Javascript
jQuery点击页面其他部分隐藏下拉菜单功能
2018/11/27 jQuery
vue实现压缩图片预览并上传功能(promise封装)
2019/01/10 Javascript
ant-design-vue中tree增删改的操作方法
2020/11/03 Javascript
JavaScript实现网页跨年倒计时
2020/12/02 Javascript
[02:34]2016完美“圣”典风云人物:BurNIng专访
2016/12/10 DOTA
Python的Bottle框架中获取制定cookie的教程
2015/04/24 Python
深入浅析Python字符编码
2015/11/12 Python
Python中的探索性数据分析(功能式)
2017/12/22 Python
Python中的引用知识点总结
2019/05/20 Python
Django实现网页分页功能
2019/10/31 Python
Python跑循环时内存泄露的解决方法
2020/01/13 Python
关于Python Tkinter Button控件command传参问题的解决方式
2020/03/04 Python
django实现日志按日期分割
2020/05/21 Python
Python正则表达式高级使用方法汇总
2020/06/18 Python
python调用百度AI接口实现人流量统计
2021/02/03 Python
HTML5 Canvas 起步(2) - 路径
2009/05/12 HTML / CSS
办公室秘书岗位职责范本
2014/02/11 职场文书
司机检讨书
2014/02/13 职场文书
预备党员入党自我评价范文
2014/03/10 职场文书
爱祖国演讲稿
2014/05/04 职场文书
群众路线教育实践活动思想汇报(2014特荐篇)
2014/09/16 职场文书
谢师宴答谢词
2015/01/05 职场文书
导游词欢迎词
2015/02/02 职场文书
涨价通知怎么写
2015/04/23 职场文书
家属联谊会致辞
2015/07/31 职场文书
小学大队长竞选稿
2015/11/20 职场文书
django学习之ajax post传参的2种格式实例
2021/05/14 Python