概念
z-index 屬性設置元素的堆疊順序柏腻。擁有更高堆疊順序的元素總是會處于堆疊順序較低的元素的前面。
層級關系的比較
1. 對于同級元素症虑,默認(或position:static)情況下文檔流后面的元素會覆蓋前面的跟束。
2. 對于同級元素,position不為static且z-index存在的情況下z-index大的元素會覆蓋z-index小的元素弛针,即z-index越大優(yōu)先級越高。
3. IE6/7下position不為static李皇,且z-index不存在時z-index為0削茁,除此之外的瀏覽器z-index為auto。
4. z-index為auto的元素不參與層級關系的比較掉房,由向上遍歷至此且z-index不為auto的元素來參與比較茧跋。
順序規(guī)則
如果不對節(jié)點設定 position 屬性,位于文檔流后面的節(jié)點會遮蓋前面的節(jié)點卓囚。
AB
定位規(guī)則
如果將 position 設為 static瘾杭,位于文檔流后面的節(jié)點依然會遮蓋前面的節(jié)點浮動,,所以position:static不會影響節(jié)點的遮蓋關系哪亿。
AB
如果將 position 設為 relative (相對定位)粥烁,absolute (絕對定位) 或者 fixed (固定定位)贤笆,這樣的節(jié)點會覆蓋沒有設置 position 屬性或者屬性值為 static 的節(jié)點,說明前者比后者的默認層級高讨阻。
AB
在沒有 z-index 屬性干擾的情況下, 根據這順序規(guī)則和定位規(guī)則, 我們可以做出更加復雜的結構. 這里我們對 A 和 B 都不設定 position, 但對 A 的子節(jié)點 A-1 設定position:relative. 根據順序規(guī)則, B 會覆蓋 A, 又根據定位規(guī)則 A' 會覆蓋 B.
A-1B
上面互相覆蓋在什么時候用到這樣的實現(xiàn)? 看起來偏門, 其實很常用, 比如說, 電子商務網站側欄的類目展示列表就可以用這個技巧來實現(xiàn).
下圖是某網站的類目展示區(qū)域, 二級類目的懸浮層覆蓋一級類目列表外框, 而一級類目的節(jié)點覆蓋二級類目的懸浮層. 如果使用 CSS 實現(xiàn)展示效果, 一級類目的外框相當于上面例子中的 A, 一級類目的節(jié)點相當于 A-1, 二級類目的懸浮層相當于 B.
參與規(guī)則
我們嘗試不用 position 屬性, 但為節(jié)點加上 z-index 屬性. 發(fā)現(xiàn) z-index 對節(jié)點沒起作用.z-index 屬性僅在節(jié)點的 position 屬性為 relative, absolute 或者 fixed 時生效.
ABC
ABC
默認值規(guī)則
如果所有節(jié)點都定義了 position:relative. z-index 為 0 的節(jié)點與沒有定義 z-index 在同一層級內沒有高低之分; 但 z-index 大于等于 1 的節(jié)點會遮蓋沒有定義 z-index 的節(jié)點; z-index 的值為負數的節(jié)點將被沒有定義 z-index 的節(jié)點覆蓋.
ABCD
從父規(guī)則
如果 A, B 節(jié)點都定義了 position:relative, A 節(jié)點的 z-index 比 B 節(jié)點大, 那么 A 的子節(jié)點必定覆蓋在 B 的子節(jié)點前面.
![](http://common.cnblogs.com/images/copycode.gif)
A-1B-1
![](http://common.cnblogs.com/images/copycode.gif)
如果所有節(jié)點都定義了 position:relative, A 節(jié)點的 z-index 和 B 節(jié)點一樣大, 但因為順序規(guī)則, B 節(jié)點覆蓋在 A 節(jié)點前面. 就算 A 的子節(jié)點 z-index 值比 B 的子節(jié)點大, B 的子節(jié)點還是會覆蓋在 A 的子節(jié)點前面.
很多人將 z-index 設得很大, 9999 什么的都出來了, 如果不考慮父節(jié)點的影響, 設得再大也沒用, 那是無法逾越的層級.