溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

CSS如何實現多級菜單

發布時間:2022-03-05 14:28:38 來源:億速云 閱讀:259 作者:小新 欄目:web開發

這篇文章主要為大家展示了“CSS如何實現多級菜單”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“CSS如何實現多級菜單”這篇文章吧。

  這是一個相當炫的功能,讓網頁看起來像桌面程序,如window的開始菜單。實現原理基本和純CSS相冊差不多,但要注意的事項比較多,讓我們一步步來吧。

  先來一個非常簡單的一級菜單與懸停效果。

  <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>

  結構很熟悉吧,就是把原來放圖片的地方換成文字而已。我還特意標出來了。接著下來的表現層代碼非常簡單。

  *{

  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的位置改為如下代碼:

  <ul>

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

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

  </ul>

  我們在各游覽器看一下,感覺非常乏力。IE6與Opera10的二級菜單項是垂直的,但我們并沒有清除浮動???firefox3.5與chrome與safari4的二級菜單項是水平分布了,但上面好像多出一個菜單項&hellip;&hellip;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控制樣式的切換。于是結構層改寫如下:

  <divclass="menu">

  <ul>

  <li>

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

  <ul>

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

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

  </ul>

  </li>

  <li>

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

  <ul>

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

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

  </ul>

  </li>

  <li>

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

  </li>

  <li>

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

  </li>

  </ul>

  </div>


CSS如何實現多級菜單CSS如何實現多級菜單


以上是“CSS如何實現多級菜單”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

css
AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女