成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

CSS如何實(shí)現(xiàn)多級(jí)菜單

這篇文章主要為大家展示了“CSS如何實(shí)現(xiàn)多級(jí)菜單”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“CSS如何實(shí)現(xiàn)多級(jí)菜單”這篇文章吧。

為滄縣等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及滄縣網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、滄縣網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!

這是一個(gè)相當(dāng)炫的功能,讓網(wǎng)頁看起來像桌面程序,如window的開始菜單。實(shí)現(xiàn)原理基本和純CSS相冊(cè)差不多,但要注意的事項(xiàng)比較多,讓我們一步步來吧。

先來一個(gè)非常簡單的一級(jí)菜單與懸停效果。

<ulid="menu">

<li>

<ahref="http://www.php.cn/">

菜單一<!--小圖--><span><!--大圖--></span>

</a>

</li>

<li>

<ahref="http://www.php.cn/">

菜單二<!--小圖--><span><!--大圖--></span>

</a>

</li>

<li>

<ahref="http://www.php.cn/">

菜單三<!--小圖--><span><!--大圖--></span>

</a>

</li>

<liclass="last">

<ahref="http://www.php.cn/">

菜單四<!--小圖--><span><!--大圖--></span>

</a>

</li>

</ul>

結(jié)構(gòu)很熟悉吧,就是把原來放圖片的地方換成文字而已。我還特意標(biāo)出來了。接著下來的表現(xiàn)層代碼非常簡單。

*{

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;

}

這里有兩個(gè)值得注意的地方。我們先說第一個(gè)。子菜單(span元素)的top應(yīng)該能使其頂部停留在a元素的范圍內(nèi),如果包含塊是li元素,同理。當(dāng)span的top值大于32px,如40px,我們就無法把鼠標(biāo)移到span元素上。因?yàn)殡x開了a:hover的作用范圍,span元素又重新隱藏。

.menulispan{

display:none;

position:absolute;

left:0;

top:40px;/*★★修改這里★★*/

width:200px;

height:150px;

background:#B9D6FF;

}

第二個(gè)問題是IE6特有的,就是子菜單在對(duì)應(yīng)的包含塊mouseout后仍不消失的問題。hover偽類相當(dāng)于moverover與moverout。我們?cè)诳梢栽趍ouseover給它的子孫元素認(rèn)定一種樣式,mouseout時(shí)認(rèn)定另一種。換言之,display現(xiàn)在在IE6無法切換(img元素除外)。解決方法用visibility代替display。

好了,現(xiàn)在我們真正做二級(jí)菜單,把有關(guān)span的CSS全刪掉,并在結(jié)構(gòu)層原span的位置改為如下代碼:

<ul>

<li><ahref="http://www.php.cn/">二級(jí)菜單_11</a></li>

<li><ahref="http://www.php.cn/">二級(jí)菜單_12</a></li>

</ul>

我們?cè)诟饔斡[器看一下,感覺非常乏力。IE6與Opera10的二級(jí)菜單項(xiàng)是垂直的,但我們并沒有清除浮動(dòng)???firefox3.5與chrome與safari4的二級(jí)菜單項(xiàng)是水平分布了,但上面好像多出一個(gè)菜單項(xiàng)&hellip;&hellip;IE8同學(xué)這次反而是表現(xiàn)得最好的。我沒有裝IE7,所以一向忽略它。

我們重新設(shè)置一下樣式,如把包含塊改設(shè)在li元素上,讓二級(jí)菜單項(xiàng)呈垂直顯示。

*{

margin:0;

padding:0;

}

.menu{

font-size:12px;

}

.menuli{/*水平菜單*/

float:left;

list-style:none;

position:relative;/*把包含塊移動(dòng)li元素*/

}

.menua{

display:block;

/*position:relative;發(fā)現(xiàn)放在a元素中,

在標(biāo)準(zhǔn)游覽器中慘不忍睹,

和純CSS相冊(cè)3的第一個(gè)運(yùn)行框在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;

}

/*新增的二級(jí)菜單部分*/

.menuulul{

visibility:hidden;/*開始時(shí)是隱藏的*/

position:absolute;

left:0px;

top:32px;

}

.menuula:hoverul{

visibility:visible;

}

.menuululli{

clear:both;/*垂直顯示*/

text-align:left;

}

發(fā)現(xiàn)二級(jí)菜單在firefox與safari與chrome中沒有反應(yīng),彈不出來(這三個(gè)瀏覽器的CSS部分互相抄襲嚴(yán)重?。pera10表現(xiàn)得最好,IE8其次。不過,標(biāo)準(zhǔn)瀏覽器的所有元素都支持hover偽類,不像IE6,非帶href的a元素不可。我們改寫部分CSS代碼:

.menuulli:hoverul,/*非IE6*/

.menuula:hoverul{/*IE6*/

visibility:visible;

}

二級(jí)菜單能彈出來了,但那個(gè)神秘的li元素也現(xiàn)形了。我用雙重浮動(dòng)的收縮包圍(shrink-wrapping)現(xiàn)象都無法消除這個(gè)神秘的li元素。參考外國的代碼,方法是,把整個(gè)子菜單放到a元素的外面,然后用li:hover控制樣式的切換。于是結(jié)構(gòu)層改寫如下:

<divclass="menu">

<ul>

<li>

<ahref="http://www.php.cn/">菜單一</a>

<ul>

<li><ahref="http://www.php.cn/">二級(jí)菜單_11</a></li>

<li><ahref="http://www.php.cn/">二級(jí)菜單_12</a></li>

</ul>

</li>

<li>

<ahref="http://www.php.cn/">菜單二</a>

<ul>

<li><ahref="http://www.php.cn/">二級(jí)菜單_21</a></li>

<li><ahref="http://www.php.cn/">二級(jí)菜單_22</a></li>

</ul>

</li>

<li>

//***************略************

</li>

<li>

//***************略************

</li>

</ul>

</div>


CSS如何實(shí)現(xiàn)多級(jí)菜單CSS如何實(shí)現(xiàn)多級(jí)菜單

以上是“CSS如何實(shí)現(xiàn)多級(jí)菜單”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

名稱欄目:CSS如何實(shí)現(xiàn)多級(jí)菜單
標(biāo)題URL:http://jinyejixie.com/article38/jjecsp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗(yàn)定制開發(fā)、關(guān)鍵詞優(yōu)化營銷型網(wǎng)站建設(shè)、面包屑導(dǎo)航微信公眾號(hào)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
海丰县| 资兴市| 江陵县| 高淳县| 岑巩县| 黑水县| 永寿县| 德阳市| 鸡泽县| 韶关市| 成都市| 光泽县| 赣榆县| 磐安县| 宝山区| 香河县| 达孜县| 万年县| 武清区| 娄底市| 城市| 邵东县| 泸溪县| 大洼县| 柘城县| 新疆| 齐齐哈尔市| 准格尔旗| 武宁县| 邵东县| 汶川县| 项城市| 万州区| 南乐县| 长垣县| 平邑县| 孟津县| 莱州市| 贺州市| 莱芜市| 乐东|