DHTML模拟菜单

dhtml|菜单

{ 在以前的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。

时间: 2024-08-30 22:47:54

DHTML模拟菜单的相关文章

使用XML/HTC/DHTML模拟标准Windows菜单

dhtml|htc|window|xml|标准|菜单   随着internet的发展,XML作为一种跨平台的通用结构化数据描述语言越来越得到人们的重视,并已经得到了广泛应用,如MicroMedia公司出品的Dreamweaver.Flash以及游戏抢滩登录等软件都利用了XML文件作为数据存储方式,而且Microsoft.NET也是架构在XML上面的.目前出现的取代HTML语言的下一代网页制作语言XHTML(可扩展超文本标记语言),就是建立在XML基础上,因此掌握XML技术是未来网页制作者必备技能

JavaScript + PHP 应用二:网页设计中树形菜单的动态实现

树形菜单,熟悉Windows程序管理器的读者一定不会陌生.单击项目左侧的+号,项目展开:再次单击,项目收缩.读过很多篇有关树形菜单的JavaScript实现方法,原理很简单,都是利用Style中display属性的控制.笔者本文的重点并不侧重于此,倒是想谈一谈如何实现每一次从数据库中提取数据并动态更新树形菜单. 树形菜单主要用来导航.网站有很多栏目,每个栏目下有很多子栏目,栏目经常变动,如增加新栏目,改变现有栏目名称,调整主次栏目之间关系等等,如果每一次都去改动页面代码,非常不便.而且因为信息都

美化与模拟Select

select CSS模拟实现 此方法来自已经不存在的苏小雨2003版个人主页,通过2个容器模拟,并定义select偏移.第一次看到确实很惊艳.#sel_exterior { border:#366 1px solid; overflow:hidden; width:73px; clip:rect(0px 181px 18px 0px); height:20px;}#sel_inside { border:#f3f3f3 1px solid; overflow:hidden; width:71px

为ASP.NET控件加入快捷菜单(1)

asp.net|菜单|控件 为ASP.NET控件加入快捷菜单(1)           虽然快捷菜单在桌面应用程序中已经是非常通用的元素,但是由于在象ASP.NET这样的基于服务器的技术没有很好的描绘,所以在Web应用程序中快捷菜单并不是很通用.要想使用快捷菜单,浏览器必须高度支持DHTML和丰富事件模式,例如:Microsoft Internet Explorer 5.0及更高版本,或者Netscape 6.0等.然而,各种浏览器的对象模式虽然功能上大至相同,但是成员各名字却各不相同,这就需要

将ASP.NET控件加入快捷菜单

虽然快捷菜单在桌面应用程序中已经是非常通用的元素,但是由于在象ASP.NET这样的基于服务器的技术没有很好的描绘,所以在Web应用程序中快捷菜单并不是很通用.要想使用快捷菜单,浏览器必须高度支持DHTML和丰富事件模式,例如:Microsoft Internet Explorer 5.0及更高版本,或者Netscape 6.0等.然而,各种浏览器的对象模式虽然功能上大至相同,但是成员各名字却各不相同,这就需要我们自己实现对象和事件的从一种模式到到另一种模式的转换. 这里,我们创建一个针到Inte

网页菜单详解

 首先看这下面的例子(鼠标移上去): Link 1 Link 2 Link 3 Link N 菜单实例 类似这样的仿Windows下拉菜单,在网上是比较常见的,最初出现在微软网站上,之后被大量效仿. 事实上制作这样一个模拟菜单也并不是一件很困难的事,比如上面的例子代码如下: ------------------------------------------- <!-- 样式部分 --> <style type=text/css> td,div { font: normal 12p

VB6.0 菜单条控件的并列排放的问题

问题描述 VB6.0 菜单条控件的并列排放的问题 怎么样VB6.0 菜单条控件做成两个并列排放的形式,而不是展开下拉样式,并且添加超链到菜单上 解决方案 你可以用工具条按钮去模拟菜单啊,按钮设置成文字样式,效果和菜单一样的.

vb-VB的菜单条能不能增加自己的空间或者内容

问题描述 VB的菜单条能不能增加自己的空间或者内容 想要在VB6.0的菜单控件上添加自己的控件,比如帮助搜索条或者LOGO图片等,这些功能都是怎么实现的呢? 解决方案 菜单条不可以,不过可以用工具条模拟菜单条来实现. 解决方案二: 做一个自定义用户控件,里面包菜单即可

30多个CSS和JS下拉菜单资源

导航菜单是网站设计中最重要的 因素之一.网络开发人员可以使用CSS创建方便用户的横向或纵向导航菜单, 而JavaScript则使人们有可能创造更多的互动,更多的响应和更灵活的导航到任何网站.Noupe在这篇文章里面提出了25个以上(横向和纵向)多 层次的下拉菜单,包括使用了JavaScript和CSS ,你可以将这些示例和教程用你的未来网站设计计划.帕兰照常为你翻译, 你也可以查看帕兰映像之前发表的一些关于菜单应用的文章: IzzyMenu: 在线创建DHTML/CSS菜单 9款CSS菜单生成器