国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > CSS > 正文

CSS多級(jí)菜單的實(shí)現(xiàn)代碼

2024-07-11 08:59:37
字體:
供稿:網(wǎng)友

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

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

<ul id="menu">  <li>    <a href="//www.survivalescaperooms.com/rubylouvre/">      菜單一<!--小圖--><span><!--大圖--></span>    </a>  </li>  <li>    <a href="//www.survivalescaperooms.com/rubylouvre/">      菜單二<!--小圖--><span><!--大圖--></span>    </a>  </li>  <li>    <a href="//www.survivalescaperooms.com/rubylouvre/">      菜單三<!--小圖--><span><!--大圖--></span>    </a>  </li>  <li class="last">    <a href="//www.survivalescaperooms.com/rubylouvre/">      菜單四<!--小圖--><span><!--大圖--></span>    </a>  </li></ul>

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

這里有兩個(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元素又重新隱藏。

.menu li span {  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><a href="//www.survivalescaperooms.com/rubylouvre/">二級(jí)菜單_11</a></li>  <li><a href="//www.survivalescaperooms.com/rubylouvre/">二級(jí)菜單_12</a></li></ul>

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

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

* {  margin:0;  padding:0;}.menu {  font-size:12px;}.menu li {/*水平菜單*/  float:left;  list-style:none;  position:relative;/*把包含塊移動(dòng)li元素*/}.menu a {  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;}.menu a:hover {  background:#369;  color:#fff;}/*新增的二級(jí)菜單部分*/.menu ul ul {  visibility:hidden;/*開始時(shí)是隱藏的*/  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)二級(jí)菜單在firefox與safari與chrome中沒有反應(yīng),彈不出來(這三個(gè)瀏覽器的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;}

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

<div class="menu">  <ul>    <li>      <a href="//www.survivalescaperooms.com/rubylouvre/">菜單一 </a>      <ul>        <li><a href="//www.survivalescaperooms.com/rubylouvre/">二級(jí)菜單_11</a></li>        <li><a href="//www.survivalescaperooms.com/rubylouvre/">二級(jí)菜單_12</a></li>      </ul>    </li>    <li>      <a href="//www.survivalescaperooms.com/rubylouvre/">菜單二</a>      <ul>        <li><a href="//www.survivalescaperooms.com/rubylouvre/">二級(jí)菜單_21</a></li>        <li><a href="//www.survivalescaperooms.com/rubylouvre/">二級(jí)菜單_22</a></li>      </ul>    </li>    <li>    //***************略************    </li>    <li>    //***************略************    </li>  </ul></div>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 明溪县| 商都县| 新建县| 呼伦贝尔市| 苏尼特左旗| 南开区| 板桥市| 确山县| 金山区| 棋牌| 新河县| 南岸区| 曲沃县| 当涂县| 察隅县| 密云县| 溧水县| 荥阳市| 大英县| 敦煌市| 游戏| 喀喇沁旗| 两当县| 安顺市| 玉环县| 台州市| 连平县| 江都市| 乐陵市| 潍坊市| 公安县| 阿巴嘎旗| 海城市| 蛟河市| 县级市| 安国市| 博爱县| 如东县| 芷江| 余江县| 湟中县|