詳解CSS的z-index屬性(帶圖片解析)

有時候我們會使用CSS中的z-index屬性來使某些塊狀元素更有層次感。

如下圖:可以通過z-index實現鼠標居於文字後面,使得網頁更有層次感


實現上面效果的代碼如下:

[html] view plain copy
  1. <span style="font-size:24px;"><html>  
  2. <head>  
  3. <style type="text/css">  
  4. img.x  
  5. {  
  6. position:absolute;  
  7. left:0px;  
  8. top:0px;  
  9. z-index:-1  
  10. }  
  11. </style>  
  12. </head>  
  13.   
  14. <body>  
  15. <h1>這是一個標題</h1>  
  16. <img class="x" src="/i/eg_mouse.jpg" />   
  17. <p>默認的 z-index 是 0。Z-index -1 擁有更低的優先級。</p>  
  18. </body>  
  19.   
  20. </html>  
  21. </span>  

但是好多剛學習css的新手們,會對z-index屬性有些不解,明明自己設置了z-index屬性,但是問什麼看不到任何效果呢?

要解決這個問題就要去w3c上去看下官方定義:



這裏需要特別說明的是:Z-index只能工作在被明確定義了absolute,fixed或relative 這三個定位屬性的元素中,如果沒有定義position屬性,則z-index屬性不起作用。

所以Z-index 僅能在定位元素上奏效(例如 position:absolute;)

用下面的代碼和圖解來給大家做一下對比:


1,代碼中沒有定義position屬性

[html] view plain copy
  1. <span style="font-size:24px;"><!DOCTYPE html>  
  2. <html>  
  3. <head>  
  4.     <title>學習認識z-index</title>  
  5.     <meta charset="utf-8">  
  6.     <style type="text/css">  
  7.         #box{  
  8.             width: 1000px;  
  9.             height:1000px;  
  10.             border: 1px royalblue solid;  
  11.         }  
  12.         #box1{  
  13.             background-color: red;  
  14.             width: 200px;  
  15.             height: 200px;  
  16.             z-index: 999;  
  17.   
  18.   
  19.         }  
  20.         #box2{  
  21.             background-color: yellow;  
  22.             width: 200px;  
  23.             height: 200px;  
  24.             margin-left: 150px;  
  25.             z-index: 99;  
  26.         }  
  27.         #box3{  
  28.             background-color: green;  
  29.             width: 200px;  
  30.             height: 200px;  
  31.             margin-left: 300px;  
  32.             z-index: 9;  
  33.   
  34.   
  35.         }  
  36.   
  37.   
  38.     </style>  
  39. </head>  
  40. <body>  
  41. <div id="box">  
  42.     <div id="box1">  
  43.         <span >我的z-index爲999</span>  
  44.     </div>  
  45.     <div id="box2">  
  46.         <span >我的z-index爲99</span>  
  47.     </div>  
  48.     <div id="box3">  
  49.         <span >我的z-index爲9</span>  
  50.     </div>  
  51. </div>  
  52. </body>  
  53. </html>  
  54. </span>  

顯示結果如下圖:


從上圖中我們可以看出,明明我們設置了z-index屬性,但是爲什麼沒有出現任何層疊效果呢?這也就是大多數新手會遇到的問題,這時我們就要認證去W3C閱讀關於z-index的規則了,在上面的W3C規則中有一句話,大家一定要謹記:“Z-index 僅能在定位元素上奏效(例如 position:absolute;)”

下面我們就在代碼中加上position:absolute;屬性來看看顯示效果:


2,定義了position:absolute;屬性的代碼:

[html] view plain copy
  1. <!DOCTYPE html>  
  2. <html>  
  3. <head>  
  4.     <title>學習認識z-index</title>  
  5.     <meta charset="utf-8">  
  6.     <style type="text/css">  
  7.         #box{  
  8.             width: 1000px;  
  9.             height:1000px;  
  10.             border: 1px royalblue solid;  
  11.         }  
  12.         #box1{  
  13.             background-color: red;  
  14.             width: 200px;  
  15.             height: 200px;  
  16.             z-index: 999;  
  17.   
  18.             position: absolute;  
  19.   
  20.         }  
  21.         #box2{  
  22.             background-color: yellow;  
  23.             width: 200px;  
  24.             height: 200px;  
  25.             margin-left: 150px;  
  26.             z-index: 99;  
  27.   
  28.             position: absolute;  
  29.         }  
  30.         #box3{  
  31.             background-color: green;  
  32.             width: 200px;  
  33.             height: 200px;  
  34.             margin-left: 300px;  
  35.             z-index: 9;  
  36.   
  37.             position: absolute;  
  38.         }  
  39.     </style>  
  40. </head>  
  41. <body>  
  42. <div id="box">  
  43.     <div id="box1">  
  44.         <span >我的z-index爲999</span>  
  45.     </div>  
  46.     <div id="box2">  
  47.         <span >我的z-index爲99</span>  
  48.     </div>  
  49.     <div id="box3">  
  50.         <span >我的z-index爲9</span>  
  51.     </div>  
  52. </div>  
  53. </body>  
  54. </html>  

這時我們就看到了如下圖所示的層疊效果。



綜上所述,我爲大家做出瞭如下的總結,供大家參考。

CSS中z-index屬性
1,定義和用法
z-index 屬性設置元素的堆疊順序。擁有更高堆疊順序的元素總是會處於堆疊順序較低的元素的前面。
註釋:元素可擁有負的 z-index 屬性值。
註釋:Z-index 僅能在定位元素上奏效(例如 position:absolute;),
注意:Z-index只能工作在被明確定義了absolute,fixed或relative 這三個定位屬性的元素中,如果沒有定義position屬性,則z-index屬性不起作用。
2,說明
該屬性設置一個定位元素沿 z 軸的位置,z 軸定義爲垂直延伸到顯示區的軸。如果爲正數,則離用戶更近,爲負數則表示離用戶更遠。

通俗講就是z-index的值越大,就離我們越近,顯示的就靠前。




原文地址:http://blog.csdn.net/qiushi_1990/article/details/40716833

發佈了35 篇原創文章 · 獲贊 39 · 訪問量 7萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章