html与js二级菜单横排,JavaScript实现横向滑出的多级菜单效果

本文实例讲述了JavaScript实现横向滑出的多级菜单效果。分享给大家供大家参考。具体如下:

这是一款JavaScript横向滑出的多级菜单,只用鼠标放上就可以动画出现二级菜单,整体设计精美,大气,博客上也可以用哦。

运行效果截图如下:

d7dd3b9a0d66c7e49a4e6945838bda90.png

在线演示地址如下:

具体代码如下:

/p>

"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

JavaScript横向滑出的多级菜单

* {padding:0; margin:0}

body {font:12px Verdana, Arial, Helvetica}

#wrapper {width:750px; padding:25px; margin:0 auto}

#leftcolumn {float:left; width:225px}

#rightcolumn {float:left; width:525px}

.dropdown {display:block; position:relative}

.dropdown dt {width:188px; border:2px solid #9ac1c9; padding:8px; font-weight:bold; cursor:pointer; background:url(images/header.gif)}

.dropdown .upperdd {border-bottom:none}

.dropdown dt:hover {background:url(images/header_over.gif)}

.dropdown dd {position:absolute; top:0; overflow:hidden; width:208px; display:none; background:#fff; opacity:0}

.dropdown ul {width:204px; border:2px solid #9ac1c9; list-style: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}

var DDSPEED = 10;

var DDTIMER = 15;

var OFFSET = -2;

var ZINT = 100;

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);

c.style.display = 'block';

if(c.maxh && c.maxh <= c.offsetHeight){return}

else if(!c.maxh){

c.style.left = (h.offsetWidth + OFFSET) + 'px';

c.style.height = 'auto';

c.maxh = c.offsetHeight;

c.style.height = '0px';

}

ZINT = ZINT + 1;

c.style.zIndex = ZINT;

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 > (c.maxh - 2) && d == 1){

clearInterval(c.timer);

}else if(dist < 1 && d != 1){

clearInterval(c.timer);

c.style.display = 'none';

}

}

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值