国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > CSS > 正文

CSS 定位之 z-index 問題分析

2024-07-11 08:48:36
字體:
供稿:網(wǎng)友

點擊查看原圖

關(guān)于z-index,目前遇到的一些問題

1. 某些瀏覽器下元素層級遮蓋存在bug;

2. 某個元素z-index設(shè)的太大,導(dǎo)致始終無法被遮蓋;

3. js動態(tài)計算z-index,導(dǎo)致元素覆蓋關(guān)系部可控

 

層級遮蓋bug出現(xiàn)的原因:

IE6/7對z-index的表現(xiàn)跟IE8及以上瀏覽器不一致。position值為非static時,如果不設(shè)置z-index屬性,IE6/7下z-index默認(rèn)為0,而IE8及以上瀏覽器z-index為auto,且zindex:auto的元素不參與堆疊優(yōu)先級比較。

ff/chrome z-index IE6/7 IE8/9
不設(shè)置 0 auto auto
number number number number

 層級關(guān)系的比較:

先看幾點結(jié)論:

1. 對于同級元素,默認(rèn)(或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的元素不參與層級關(guān)系的比較,由向上遍歷至此且z-index不為auto的元素來參與比較。

在上面2點結(jié)論的基礎(chǔ)上,我們引入“定位樹”(非w3c官方詞匯)的概念來做層級的比較。

在定位樹這個概念下,瀏覽器在渲染dom節(jié)點時,除了生成dom樹之外,還會根據(jù)dom樹中的定位元素(position不為static)生成“定位樹”:
dom樹、定位樹對比如下(其中邊上有紅色圓圈的表示該元素position不為static):


可以這樣理解:定位樹中包含了dom樹中position不為staitc的全部元素。非同級元素比較層級關(guān)系可以這樣比較:

1. 向上遍歷定位樹的父節(jié)點直到2個元素為同級元素。

2. 根據(jù)上面的結(jié)論來最最后的比較。層級高的元素會越靠近用戶的顯示器并能覆蓋層級低的元素。

 

實例一:假設(shè)上圖中所有標(biāo)紅色元素position都不為static;且z-index=1,根據(jù)上面的比較規(guī)則可以知道:

1. c > (b && b *) > (a && a *) 即元素c及c的所有定位元素層級比a、b高

2. m > h、 g > k、d > m

實例二:假設(shè)a的position不為static,z-index屬性不存在,定位樹中a的子元素z-index一次分別為1,2,3,4...其它定位元素z-index:1:

1. 根據(jù)結(jié)論三有:IE6/7下 b > (a && a *) 即元素b的層級比a及a的所有定位元素層級高,其它瀏覽器下:i > h > b > d

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 泰兴市| 汝州市| 金溪县| 丰都县| 浦县| 博野县| 湖南省| 湛江市| 宁国市| 瓦房店市| 沙河市| 大方县| 宕昌县| 巨鹿县| 云林县| 海兴县| 锦州市| 元朗区| 社旗县| 沭阳县| 淅川县| 通化市| 仁布县| 闽侯县| 武穴市| 甘泉县| 汽车| 龙口市| 望城县| 崇仁县| 九台市| 寿阳县| 兴和县| 海淀区| 南宫市| 红原县| 文水县| 黑河市| 金坛市| 锦屏县| 和平区|