首頁 > web前端 > css教學 > CSS多層選單的實例程式碼解說

CSS多層選單的實例程式碼解說

不言
發布: 2018-11-12 15:23:39
轉載
2249 人瀏覽過

這篇文章帶給大家的內容是關於CSS多級菜單的實例代碼講解,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

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

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

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

登入後複製

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

* {

  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元素又重新隱藏。

1

2

3

4

5

6

7

8

9

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

1

2

3

4

<ul>

  <li><a href="http://www.php.cn/">二级菜单_11</a></li>

  <li><a href="http://www.php.cn/">二级菜单_12</a></li>

</ul>

登入後複製

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

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

* {

  margin:0;

  padding:0;

}

.menu {

  font-size:12px;

}

.menu li {/*水平菜单*/

  float:left;

  list-style:none;

  position:relative;/*把包含块移动li元素*/

}

.menu a {

  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;

}

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

}

登入後複製

發現二級選單在firefox與safari與chrome中沒有反應,彈不出來(這三個瀏覽器的CSS部分互相抄襲嚴重啊)。 opera10表現得最好,IE8其次。不過,標準瀏覽器的所有元素都支援hover偽類,不像IE6,非帶href的a元素不可。我們改寫部分CSS程式碼:

1

2

3

4

.menu ul li:hover ul,/*非IE6*/

.menu ul a:hover ul{/*IE6*/

  visibility:visible;

}

登入後複製

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

<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多層選單的實例程式碼解說的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
css
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板