二级菜单HTML原理,CSS多级菜单的实例代码讲解
這是一個相當炫的功能,讓網頁看起來像桌面程序,如window的開始菜單。實現原理基本和純CSS相冊差不多,但要注意的事項比較多,讓我們一步步來吧。
先來一個非常簡單的一級菜單與懸停效果。
菜單一
菜單二
菜單三
菜單四
結構很熟悉吧,就是把原來放圖片的地方換成文字而已。我還特意標出來了。接著下來的表現層代碼非常簡單。
*{
margin:0;
padding:0;
}
.menu{
font-size:12px;
}
.menuli{/*水平菜單*/
float:left;
list-style:none;
}
.menua{
display:block;
position:relative;
height:32px;
width:100px;
line-height:32px;
background:#a9ea00;
color:#ff8040;
text-decoration:none;
text-align:center;
}
.menua:hover{
background:#369;
color:#fff;
}
.menulispan{
display:none;
position:absolute;
left:0;
top:32px;
width:200px;
height:150px;
background:#B9D6FF;
}
.menua:hoverspan{
display:block;
}
這里有兩個值得注意的地方。我們先說第一個。子菜單(span元素)的top應該能使其頂部停留在a元素的范圍內,如果包含塊是li元素,同理。當span的top值大于32px,如40px,我們就無法把鼠標移到span元素上。因為離開了a:hover的作用范圍,span元素又重新隱藏。
.menulispan{
display:none;
position:absolute;
left:0;
top:40px;/*★★修改這里★★*/
width:200px;
height:150px;
background:#B9D6FF;
}
第二個問題是IE6特有的,就是子菜單在對應的包含塊mouseout后仍不消失的問題。hover偽類相當于moverover與moverout。我們在可以在mouseover給它的子孫元素認定一種樣式,mouseout時認定另一種。換言之,display現在在IE6無法切換(img元素除外)。解決方法用visibility代替display。
好了,現在我們真正做二級菜單,把有關span的CSS全刪掉,并在結構層原span的位置改為如下代碼:
- 二級菜單_11
 - 二級菜單_12
 
我們在各游覽器看一下,感覺非常乏力。IE6與Opera10的二級菜單項是垂直的,但我們并沒有清除浮動啊?firefox3.5與chrome與safari4的二級菜單項是水平分布了,但上面好像多出一個菜單項……IE8同學這次反而是表現得最好的。我沒有裝IE7,所以一向忽略它。
我們重新設置一下樣式,如把包含塊改設在li元素上,讓二級菜單項呈垂直顯示。
*{
margin:0;
padding:0;
}
.menu{
font-size:12px;
}
.menuli{/*水平菜單*/
float:left;
list-style:none;
position:relative;/*把包含塊移動li元素*/
}
.menua{
display:block;
/*position:relative;發現放在a元素中,
在標準游覽器中慘不忍睹,
和純CSS相冊3的第一個運行框在chrome中遇到的bug一樣*/
height:32px;
width:100px;
line-height:32px;
background:#a9ea00;
color:#ff8040;
text-decoration:none;
text-align:center;
}
.menua:hover{
background:#369;
color:#fff;
}
/*新增的二級菜單部分*/
.menuulul{
visibility:hidden;/*開始時是隱藏的*/
position:absolute;
left:0px;
top:32px;
}
.menuula:hoverul{
visibility:visible;
}
.menuululli{
clear:both;/*垂直顯示*/
text-align:left;
}
發現二級菜單在firefox與safari與chrome中沒有反應,彈不出來(這三個瀏覽器的CSS部分互相抄襲嚴重啊)。opera10表現得最好,IE8其次。不過,標準瀏覽器的所有元素都支持hover偽類,不像IE6,非帶href的a元素不可。我們改寫部分CSS代碼:
.menuulli:hoverul,/*非IE6*/
.menuula:hoverul{/*IE6*/
visibility:visible;
}
二級菜單能彈出來了,但那個神秘的li元素也現形了。我用雙重浮動的收縮包圍(shrink-wrapping)現象都無法消除這個神秘的li元素。參考外國的代碼,方法是,把整個子菜單放到a元素的外面,然后用li:hover控制樣式的切換。于是結構層改寫如下:
菜單一
- 二級菜單_11
 - 二級菜單_12
 
菜單二
- 二級菜單_21
 - 二級菜單_22
 
//***************略************
//***************略************
總結
以上是生活随笔為你收集整理的二级菜单HTML原理,CSS多级菜单的实例代码讲解的全部內容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: flask mysql sql注入_Py
 - 下一篇: 杭电 1142 十字链表存储