溫馨提示×

溫馨提示×

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

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

使用CSS怎么實現多級菜單

發(fā)布時間:2021-05-14 16:44:51 來源:億速云 閱讀:250 作者:Leah 欄目:web開發(fā)

這期內容當中小編將會給大家?guī)碛嘘P使用CSS怎么實現多級菜單,文章內容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

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

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

* {
  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應該能使其頂部停留在a元素的范圍內,如果包含塊是li元素,同理。當span的top值大于32px,如40px,我們就無法把鼠標移到span元素上。因為離開了a:hover的作用范圍,span元素又重新隱藏。

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

我們在各游覽器看一下,感覺非常乏力。IE6與Opera10的二級菜單項是垂直的,但我們并沒有清除浮動???firefox3.5與chrome與safari4的二級菜單項是水平分布了,但上面好像多出一個菜單項&hellip;&hellip;IE8同學這次反而是表現得最好的。我沒有裝IE7,所以一向忽略它。

我們重新設置一下樣式,如把包含塊改設在li元素上,讓二級菜單項呈垂直顯示。

* {
  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ā)現放在a元素中,
  在標準游覽器中慘不忍睹,
  和純CSS相冊3的第一個運行框在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ā)現二級菜單在firefox與safari與chrome中沒有反應,彈不出來(這三個瀏覽器的CSS部分互相抄襲嚴重?。pera10表現得最好,IE8其次。不過,標準瀏覽器的所有元素都支持hover偽類,不像IE6,非帶href的a元素不可。我們改寫部分CSS代碼:

.menu ul li:hover ul,/*非IE6*/
.menu ul a:hover ul{/*IE6*/
  visibility:visible;
}

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

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

css的基本語法是什么

css的基本語法是:1、css規(guī)則由選擇器和一條或多條聲明兩個部分構成;2、選擇器通常是需要改變樣式的HTML元素;3、每條聲明由一個屬性和一個值組成;4、屬性和屬性值被冒號分隔開。

上述就是小編為大家分享的使用CSS怎么實現多級菜單了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

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

css
AI