您的位置:首页精文荟萃软件资讯 → DHTML模拟菜单

DHTML模拟菜单

时间:2004/10/8 13:17:00来源:本站整理作者:蓝点我要评论(0)

{ 在以前的HTML里,元素的位置只能依次排列,我们很难精确地定位与控制网页中的一些元素。CSS2Cascading Style Sheet Level 2,层叠样式单第二版的布局Layout属性出现并得到浏览器的广泛支持之后,我们不仅可以静态地实现以上目的,而且可以根据鼠标、键盘、时间等预定义好的外界事件动态地改变布局。时下非常流行的网页中“活动的层”便是它的一种形象的运用,我们这里要讲的是如何运用这些属性结合一些DHTML对象在网页中实现类似Windows窗口的下拉菜单(如图所示)。请看以下代码及详细说明。


<-- 以下部分应该插在代码的<head>之后 -->


<style><--


/ 这是一些CSS样式。其中″btnTD″是按钮在被按下之前“凸起”的样式类:边框被设置为宽度为1个像素的实线,其中左边框和上边框颜色为浅色(这里为白色),右下边框为深色(深灰色),如果背景为灰色的HTML元素(如单元格)使用这个样式的话,那就非常像一个“凸出”的按钮;“btnDTD”是按钮被按下时“凹下”的样式。 /


.btnTD  border-left 1 solid #ffffff border-right 1 solid #808080


border-top 1 solid #ffffff border-bottom 1 solid #808080 


.btnDTD  border-left 1 solid #808080 border-right 1 solid #ffffff


border-top 1 solid #808080 border-bottom 1 solid #ffffff 


td  font-family 宋体 font-size 9pt 


--></style>


<script language=″JavaScript″><--


//判断哪个按钮被按下的全局变量


var intBlnClk=0


//鼠标经过、离开、点击更改单元格CSS样式的函数


function mOvrOutobjSrc


var argvargcblnActivestrColorstrBgColorstrClassstrClassDstrCursor


argv=mOvrOut.argumentsargc=argv.length


/默认情况下不将当前对象置为“激活”/


blnActive=argc>1﹖evalargv[1]false


/默认鼠标经过当前对象的样式为“凸出的按钮形”/


strClass=argc>2 && argv[2]=′′﹖argv[2]′btnTD′


/默认鼠标点击的时候当前对象为“凹下的按钮形”/


strClassD=argc>3 && argv[3]=′′﹖argv[3]′btnDTD′


/将当前对象激活时候的前景色为白色、背景色为蓝色、鼠标样式为手形/


strColor=′#ffffff′strBgColor=′#000080′strCursor=′hand′


/IE4及其更高版本才支持这些JavaScript对CSS样式的动态改变/


ifdocument.all


//将当前对象的鼠标样式置为参数传递值


objSrc.style.cursor=strCursor


//如果是鼠标进入当前对象范围


ifobjSrc.containsevent.fromElement


/设置为活动样式/


ifblnActive objSrc.bgColor=strBgColorobjSrc.style.color=strColor 


/当前对象不需要置为活动样式的时候,如果本来的样式是“凸出的按钮形”则置为“凹下的按钮形”,反之亦然/


else objSrc.className=intBlnClk=0﹖strClassDstrClass 


//鼠标离开当前对象区域


else ifobjSrc.containsevent.toElement


//将这些样式置为默认值


objSrc.bgColor=′′objSrc.style.color=′′objSrc.className=′′ 





/ 显示/隐藏层的通用函数。用objNS、objIE、strStu作为参数,其中objNS和objIE分别是Netscape和IE的“层”对象,strStu为层的状态。因为篇幅所限,请查看本文尾部说明。 /


function shoHidLayers


/ 调用上面的函数,显示/隐藏参数传递的层,这样是为了简化代码。这里不给出详细函数。/


function showLayerintCurrent


//--></script></head>


<body onMouseDown=″ifwindow.event.srcElement.style.color==′′ showLayer1′hide′″>


<-- 以上body部分的作用是当鼠标没有按下任何按钮的时候隐藏所有应该隐藏的“菜单”。以下是两个用CSS布局定义的层,名为“menu”的层的初始状态为:在屏幕上的绝对位置为(1212),可视,层z-index属性为100;“menu1”为不可视。 -->


<div id=″menu″ style=″positionabsolutevisibility visibleleft12pxtop12px z-index 100″><table border=″1″ cellspacing=″0″ cellpadding=″2″ bgcolor=″#c0c0c0″ bordercolor=″#c0c0c0″>


<tr><td onMouseOver=″mOvrOutthis″ onMouseOut=″mOvrOutthis″ onClick=″mOvrOutthisfalse′btnDTD′showLayer1″>天极网</td></tr>


</table></div>


<div id=″menu1″ style=″positionabsolutevisibility hiddenleft11pxtop34px z-index 1″><table border=″0″ cellpadding=″2″ cellspacing=″0″ bgcolor=″#c0c0c0″ class=″btnTD″>


<tr><td onMouseOver=″mOvrOutthistrue″ onMouseOut=″mOvrOutthis″ width=″100%″nowrap onClick=″window.location=′http//www.pcwclub.com/′showLayer1′hide′″>电脑报读者俱乐部</td></tr>


</table></div>


因为篇幅所限,一些函数不能详细给出及说明,如果需要完整代码请访问以下链接:http//ctsight.topcool.net/documents/menu.html。


相关阅读 Windows错误代码大全 Windows错误代码查询激活windows有什么用Mac QQ和Windows QQ聊天记录怎么合并 Mac QQ和Windows QQ聊天记录Windows 10自动更新怎么关闭 如何关闭Windows 10自动更新windows 10 rs4快速预览版17017下载错误问题Win10秋季创意者更新16291更新了什么 win10 16291更新内容windows10秋季创意者更新时间 windows10秋季创意者更新内容kb3150513补丁更新了什么 Windows 10补丁kb3150513是什么

文章评论
发表评论

热门文章 360快剪辑怎么使用 36金山词霸如何屏幕取词百度收购PPS已敲定!3

最新文章 微信3.6.0测试版更新了微信支付漏洞会造成哪 360快剪辑怎么使用 360快剪辑软件使用方法介酷骑单车是什么 酷骑单车有什么用Apple pay与支付宝有什么区别 Apple pay与贝贝特卖是正品吗 贝贝特卖网可靠吗

人气排行 xp系统停止服务怎么办?xp系统升级win7系统方电脑闹钟怎么设置 win7电脑闹钟怎么设置office2013安装教程图解:手把手教你安装与qq影音闪退怎么办 QQ影音闪退解决方法VeryCD镜像网站逐个数,电驴资料库全集同步推是什么?同步推使用方法介绍QQ2012什么时候出 最新版下载EDiary——一款好用的电子日记本