|
導(dǎo)讀網(wǎng)頁的本質(zhì)就是超級文本標(biāo)記語言,通過結(jié)合使用其他的Web技術(shù)(如:腳本語言、公共網(wǎng)關(guān)接口、組件等),可以創(chuàng)造出功能強(qiáng)大的網(wǎng)頁。因而,超級文本標(biāo)記語言是萬維網(wǎng)(Web)編程的基礎(chǔ),也就是說萬維網(wǎng)是建立... 網(wǎng)頁的本質(zhì)就是超級文本標(biāo)記語言,通過結(jié)合使用其他的Web技術(shù)(如:腳本語言、公共網(wǎng)關(guān)接口、組件等),可以創(chuàng)造出功能強(qiáng)大的網(wǎng)頁。因而,超級文本標(biāo)記語言是萬維網(wǎng)(Web)編程的基礎(chǔ),也就是說萬維網(wǎng)是建立在超文本基礎(chǔ)之上的。超級文本標(biāo)記語言之所以稱為超文本標(biāo)記語言,是因?yàn)槲谋局邪怂^“超級鏈接”點(diǎn)。 本篇文章給大家?guī)淼膬?nèi)容是關(guān)于CSS多級菜單的實(shí)例代碼講解,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。這是一個相當(dāng)炫的功能,讓網(wǎng)頁看起來像桌面程序,如window的開始菜單。實(shí)現(xiàn)原理基本和純CSS相冊差不多,但要注意的事項(xiàng)比較多,讓我們一步步來吧。 先來一個非常簡單的一級菜單與懸停效果。 <ul id="menu">
<li>
<a href="http://www.php.cn/">
菜單一<!--小圖--><span><!--大圖--></span>
</a>
</li>
<li>
<a href="http://www.php.cn/">
菜單二<!--小圖--><span><!--大圖--></span>
</a>
</li>
<li>
<a href="http://www.php.cn/">
菜單三<!--小圖--><span><!--大圖--></span>
</a>
</li>
<li class="last">
<a href="http://www.php.cn/">
菜單四<!--小圖--><span><!--大圖--></span>
</a>
</li>
</ul>結(jié)構(gòu)很熟悉吧,就是把原來放圖片的地方換成文字而已。我還特意標(biāo)出來了。接著下來的表現(xiàn)層代碼非常簡單。 * {
margin:0;
padding:0;
}
.menu {
font-size:12px;
}
.menu li {/*水平菜單*/
float:left;
list-style:none;
}
.menu a {
display:block;
position:relative;
height:32px;
width:100px;
line-height:32px;
background:#a9ea00;
color:#ff8040;
text-decoration:none;
text-align:center;
}
.menu a:hover {
background:#369;
color:#fff;
}
.menu li span {
display:none;
position:absolute;
left:0;
top:32px;
width:200px;
height:150px;
background:#B9D6FF;
}
.menu a:hover span {
display:block;
}這里有兩個值得注意的地方。我們先說第一個。子菜單(span元素)的top應(yīng)該能使其頂部停留在a元素的范圍內(nèi),如果包含塊是li元素,同理。當(dāng)span的top值大于32px,如40px,我們就無法把鼠標(biāo)移到span元素上。因?yàn)殡x開了a:hover的作用范圍,span元素又重新隱藏。 .menu li span {
display:none;
position:absolute;
left:0;
top:40px;/*★★修改這里★★*/
width:200px;
height:150px;
background:#B9D6FF;
}第二個問題是IE6特有的,就是子菜單在對應(yīng)的包含塊mouseout后仍不消失的問題。hover偽類相當(dāng)于moverover與moverout。我們在可以在mouseover給它的子孫元素認(rèn)定一種樣式,mouseout時認(rèn)定另一種。換言之,display現(xiàn)在在IE6無法切換(img元素除外)。解決方法用visibility 代替display。 好了,現(xiàn)在我們真正做二級菜單,把有關(guān)span的CSS全刪掉,并在結(jié)構(gòu)層原span的位置改為如下代碼: <ul> <li><a href="http://www.php.cn/">二級菜單_11</a></li> <li><a href="http://www.php.cn/">二級菜單_12</a></li> </ul> 我們在各游覽器看一下,感覺非常乏力。IE6與Opera10的二級菜單項(xiàng)是垂直的,但我們并沒有清除浮動啊?firefox3.5與chrome與safari4的二級菜單項(xiàng)是水平分布了,但上面好像多出一個菜單項(xiàng)……IE8同學(xué)這次反而是表現(xiàn)得最好的。我沒有裝IE7,所以一向忽略它。 我們重新設(shè)置一下樣式,如把包含塊改設(shè)在li元素上,讓二級菜單項(xiàng)呈垂直顯示。 * {
margin:0;
padding:0;
}
.menu {
font-size:12px;
}
.menu li {/*水平菜單*/
float:left;
list-style:none;
position:relative;/*把包含塊移動li元素*/
}
.menu a {
display:block;
/*position:relative;發(fā)現(xiàn)放在a元素中,
在標(biāo)準(zhǔn)游覽器中慘不忍睹,
和純CSS相冊3的第一個運(yùn)行框在chrome中遇到的bug一樣*/
height:32px;
width:100px;
line-height:32px;
background:#a9ea00;
color:#ff8040;
text-decoration:none;
text-align:center;
}
.menu a:hover {
background:#369;
color:#fff;
}
/*新增的二級菜單部分*/
.menu ul ul {
visibility:hidden;/*開始時是隱藏的*/
position:absolute;
left:0px;
top:32px;
}
.menu ul a:hover ul{
visibility:visible;
}
.menu ul ul li {
clear:both;/*垂直顯示*/
text-align:left;
}發(fā)現(xiàn)二級菜單在firefox與safari與chrome中沒有反應(yīng),彈不出來(這三個瀏覽器的CSS部分互相抄襲嚴(yán)重啊)。opera10表現(xiàn)得最好,IE8其次。不過,標(biāo)準(zhǔn)瀏覽器的所有元素都支持hover偽類,不像IE6,非帶href的a元素不可。我們改寫部分CSS代碼: .menu ul li:hover ul,/*非IE6*/
.menu ul a:hover ul{/*IE6*/
visibility:visible;
}二級菜單能彈出來了,但那個神秘的li元素也現(xiàn)形了。我用雙重浮動的收縮包圍(shrink-wrapping)現(xiàn)象都無法消除這個神秘的li元素。參考外國的代碼,方法是,把整個子菜單放到a元素的外面,然后用li:hover控制樣式的切換。于是結(jié)構(gòu)層改寫如下: <div class="menu">
<ul>
<li>
<a href="http://www.php.cn/">菜單一 </a>
<ul>
<li><a href="http://www.php.cn/">二級菜單_11</a></li>
<li><a href="http://www.php.cn/">二級菜單_12</a></li>
</ul>
</li>
<li>
<a href="http://www.php.cn/">菜單二</a>
<ul>
<li><a href="http://www.php.cn/">二級菜單_21</a></li>
<li><a href="http://www.php.cn/">二級菜單_22</a></li>
</ul>
</li>
<li>
//***************略************
</li>
<li>
//***************略************
</li>
</ul>
</div>以上就是CSS多級菜單的實(shí)例代碼講解的詳細(xì)內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章! 網(wǎng)站建設(shè)是一個廣義的術(shù)語,涵蓋了許多不同的技能和學(xué)科中所使用的生產(chǎn)和維護(hù)的網(wǎng)站。 |
溫馨提示:喜歡本站的話,請收藏一下本站!