html中左侧二级菜单栏,div+css二级弹出菜单的制作

div+css二级弹出菜单的制作

1.效果图:当鼠标移动到左侧菜单的时候,右侧会弹出对应的二级菜单,当鼠标移开的时候,二级菜单隐藏。

f31a4241e2be6a9bbb70eb18cfce0c22.png

2.在一级菜单上新增二级菜单列表,代码如下

1130f33982ab4f103bcbecf3ca4690c3.png

3.预览效果如下,样式乱了,这是因为一级菜单和二级菜单重合在一起了,并没有在右侧弹出

518af8e336ecac9f1a90bb8d302fb6ec.png

4.让二级菜单隐藏,新增如下代码

9d5c2b6e80a9be314c662bc4215f7e2d.png

5.隐藏后的效果,但仅仅隐藏和显示二级菜单还是不够的,因为现在二级菜单的位置还不对,我们期望二级菜单是在一级菜单右侧展示的

1d68b2570990946ee0797a477b25f27d.png

6.添加如下代码,此代码定义了一级菜单的li是相对定位,二级菜单的ul是绝对定位,并且是在父级菜单li左侧100px,顶部0px下的,这样就把二级菜单定位在了一级菜单li右侧。至于#menu ul li.current ul{display:block;} 是给给li定义一个current样式,当li引用current样式的时候 二级菜单的ul为显示状态,这个样式需要JS来控制。

a3d12adf233493bcf106c908254fcff8.png

7.首先在火狐的firebug下定位一级菜单li的代码

c4c0460f0cec630a1507b010bbb38176.png

8.在火狐firebug的编辑模式下,给li添加class="current",效果如下现在已经实现了二级菜单的定位,那现在要解决的就是li什么时候添加current样式,什么时候去除current样式,这就需要js代码的控制了!

4f2218ec2a0016d8075aa46eaf169982.png

9.添加如下JS代码

0c646fbbf82a8183faa19e5c9f14b877.png

10.代码解释:首先获取id为menu的元素对象。    再获取 menu下的li对象allli    循环allli中的每个元素,并赋值给node也就是一级菜单下的每个li。    Onmouseover是指当鼠标移动到li上的时候,给li添加样式current,让二级菜单的ul显示。    Onmouseout是只当鼠标移开li的时候,把li的current样式清空,即不再引用current样式,也就是二级菜单仍然是hidden的状态。最终浏览效果如下:

3a0e7b549feffcf21beeb13c34f2ae37.png

举报/反馈

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值