首页 > 语言 > JavaScript > 正文

通用的二级菜单代码(css+javascript)

2024-05-06 14:14:59
字体:
来源:转载
供稿:网友
]但在《CSS二级菜单》中,如果一级菜单中的超链接是#,那么只要单击该一级菜单,那么与这个一级菜单对应的二级菜单就会一直显示在网页中,不能隐藏,是一个小小的bug。
后来仔细的想了一想,其实,无论是什么样的二级菜单,原理都是一样的:
1、每一个一级菜单都会对应一个层,而这个层里放着的就是该一级菜单对应的二级菜单。
2、默认情况下,二级菜单这个层是隐藏的,在CSS中将层的display属性值设为none,可以达到这一目的。
3、当鼠标放在一级菜单上时,将对应的二级菜单层显示出来,在CSS中将层的display属性值设为block,可以达到这一目的。
4、当鼠标从一级菜单中移开时,对应的二级菜单层隐藏。
5、当然,如果鼠标从一级菜单移到二级菜单上时,二级菜单也不能隐藏,因此,对二级菜单而言,也必须将其设为,当鼠标在其上时显示当前层,当鼠标移开时隐藏当前层。
好了,有了基本思路之后,我们就可以开始动手创建二级菜单了。
首先,创建一个层,这个层用于包含所有的一级菜单和二级菜单。之所以要创建这个层,是为了可以方便地对整个菜单进行设置,比较说让菜单层中显示,或让菜单居右显示等等,
代码如下所示:
代码如下:
<div id="menu">
</div>

然后,在menu层里添加一级菜单,这个一级菜单可以是直接的超链接,也可以是span或div。也许有人要问,一级菜单不就是超链接吗?的确可以这么说,但是你也同样可以将超链接作用在span或div上,而使用span或div还有一个好处,这个好处在后面再说,在这里,我们还是简单地添加几个超链接吧。
代码如下:
<div id="menu">
<a href="#">菜单一</a> | 
<a href="#">菜单二</a> | 
</div>

第三步,在menu层里添加二级菜单层,如下所示。
代码如下:
<div id="menu">
<a href="#">菜单一</a> | 
<a href="#">菜单二</a> | 
<div id="div1">
<a href="#">子菜单一</a>
</div>
<div id="div2">
<a href="#">子菜单一</a>
<a href="#">子菜单二</a>
</div>
</div>

为什么要将二级菜单层放在menu层中呢?因为这样做可以方便的设置二级菜单层的位置。

第四步,使用CSS设置二级菜单层的位置。通常设置一个层的位置都会使用到CSS的position属性,这个属性值常用的有relative、absolute和fixed三种。其中absolute为绝对定位,使用这种方式设置层的位置时,该层是以整个<body>为基础定位,因此,如果浏览器窗口大小改变时,层的位置是会变动的;fixed是相对定位,而这个“相对”是相对浏览器窗口的定位,假设层离浏览器窗口顶部10像素时,无论怎么拖动滚动条,这个层都会在离浏览器窗口顶部10像素的位置出现,即会一直显示在浏览器窗口中。relative也是相对定位,在这个相对定位是相对这个层的原来的位置的定位。在relative模式下,浏览器会先输出层的位置,再相对这个层的位置进行偏移,这也就是我们为什么将二级菜单层放在menu层中的原因。因为二级菜单层一旦产生,它只能相对以前的位置偏移,所以浏览器窗口再怎么变化,也不会影响到层的位置。由于二级菜单层所在位置不同,所以要为每一个二级菜单层设置不同的偏移量,如下所示。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选