CSS深入理解之z-index 筆記

z-index 與 css 定位屬性

z-index 只對(duì)定位元素有作用。

{position:relative;z-index:2;}
{position:absolute;z-index:2;}
{position:fixed;z-index:2;}
{position:sticky;z-index:2;}

如果定位元素z-index沒(méi)有發(fā)生嵌套:

  • 后來(lái)居上迟杂;
  • 哪個(gè)值大哪個(gè)在上;

如果定位元素z-index發(fā)生嵌套:

  • 以祖先元素為標(biāo)準(zhǔn)(z-index不為auto)

css 中的層疊上下文和層疊等級(jí)

層疊上下文是HTML元素中的一個(gè)三維概念截亦,表示元素在z軸上距離人眼更近宴胧。

具有層疊上下文的元素:

  • 頁(yè)面根元素天生具有層疊上下文,稱(chēng)為“根層疊上下文”。
  • z-index 值為數(shù)值的定位元素具有層疊上下文精钮。
  • 其它屬性

層疊上下文中的每個(gè)元素都有一個(gè)層疊等級(jí)威鹿,決定了同一個(gè)層疊上下文中元素在z軸上的顯示順序。遵循“后來(lái)居上”“誰(shuí)值大誰(shuí)在上”的層疊準(zhǔn)則轨香。

層疊等級(jí)(stacking level) 和 z-index 不是一個(gè)東西忽你。普通元素也有層疊等級(jí)。

層疊等級(jí)是放在同一個(gè)層疊上下文中來(lái)進(jìn)行比較的臂容,不在同一個(gè)層疊上下文中沒(méi)有意義科雳。

層疊上下文的特性

  • 層疊上下文可以嵌套,組合成一個(gè)分層次的層疊上下文脓杉。
  • 每個(gè)層疊上下文和兄弟元素獨(dú)立:當(dāng)進(jìn)行層疊變化或渲染時(shí)糟秘,只影響后代元素。
  • 每個(gè)層疊上下文是自成體系的:當(dāng)元素的內(nèi)容被層疊后球散,整個(gè)元素被認(rèn)為是在父層的層疊順序中尿赚。

層疊順序

層疊順序表示元素發(fā)生層疊時(shí)特定的垂直顯示順序。

7階層疊等級(jí)(stacking level)

層疊等級(jí)的比較要在同一個(gè)層疊上下文中

看下面的例子:

.inline-block{
  display:inline-block;
  background:olive;
  margin:-30px;
}
.block{
  display:block;
  background:green;
}

z-index 與層疊上下文

  1. 定位元素默認(rèn)z-index:auto可以看成是z-index:0蕉堰;

為何定位元素會(huì)覆蓋普通元素凌净?

定位元素默認(rèn)z-index:auto,根據(jù)層疊順序表z-index:auto是大于inline/inline-block的屋讶,所以定位后冰寻,就會(huì)覆蓋普通元素。

  1. z-index 不為 auto 的定位元素會(huì)創(chuàng)建層疊上下文丑婿;

從層疊順序上講性雄,z-index:auto可以看成是z-index:0
但從層疊上下文來(lái)講羹奉,z-index:auto不會(huì)產(chǎn)生層疊上下文秒旋,z-index:0則會(huì)產(chǎn)生層疊上下文。

  1. z-index 層疊順序的比較止步于父級(jí)層疊上下文诀拭;

其它具有層疊上下文的css屬性

  1. z-index 值不為 auto 的子 flex 項(xiàng)(父元素display:flex|inline-flex)迁筛。
<div class="box">
  <div class="d1">
    <div class="d2"></div>
  </div>
</div>

.box{
  margin:100px;background:blue;
  display:flex;
}
.d1{z-index:1;} /*這里的值不是auto,所以父元素添加flex后才有了層疊上下文*/
.d2{
  width:100px;height:100px;background:green;
  position:relative;top:-20px;left:-20px;
  z-index:-1;
}
  1. 元素的 opacity 值不是1耕挨。
<div class="box">
  <div class="d1"></div>
</div>

.box{
  margin:100px;background:blue;
  opacity:0.5; /*opacity不為1產(chǎn)生層疊上下文*/
}
.d1{
  width:100px;height:100px;background:green;
  position:relative;top:-20px;left:-20px;
  z-index:-1;
}
  1. 元素的 transform 值不是none细卧。
<div class="box">
  <div class="d1"></div>
</div>

.box{
  margin:100px;background:blue;
  transform:rotate(15deg); /*任意非none值*/
}
.d1{
  width:100px;height:100px;background:green;
  position:relative;top:-20px;left:-20px;
  z-index:-1;
}
  1. 元素 mix-blend-mode 值不是 normal
  1. 元素的 filter 值不是 none筒占。
  1. 元素的 isolation 值是 isolate贪庙。
  1. position:fixed聲明。
  1. will-change 指定的屬性值為上面任意一個(gè)翰苫。
  1. 元素的-webkit-overflow-scrolling 設(shè)為 touch止邮。
    -webkit-overflow-scrolling 屬性控制元素在移動(dòng)設(shè)備上是否使用滾動(dòng)回彈效果.
  • auto 使用普通滾動(dòng), 當(dāng)手指從觸摸屏上移開(kāi)这橙,滾動(dòng)會(huì)立即停止。
  • touch 使用具有回彈效果的滾動(dòng), 當(dāng)手指從觸摸屏上移開(kāi)导披,內(nèi)容會(huì)繼續(xù)保持一段時(shí)間的滾動(dòng)效果屈扎。繼續(xù)滾動(dòng)的速度和持續(xù)的時(shí)間和滾動(dòng)手勢(shì)的強(qiáng)烈程度成正比。同時(shí)也會(huì)創(chuàng)建一個(gè)新的堆棧上下文撩匕。

z-index 與其它 css 屬性層疊上下文的關(guān)系

  1. 不支持z-index即上面的9中css屬性的層疊上下文元素的層疊順序均是z-index:auto級(jí)別鹰晨。
  2. 依賴(lài)z-index的層疊上下文元素的層疊順序取決于z-index的值。

依賴(lài)z-index值創(chuàng)建層疊上下文的情況:

  • position 值為relative/absolutefixed(部分瀏覽器)止毕。
  • display:flex|inline-flex容器的子flex項(xiàng)模蜡。

z-index 最佳實(shí)踐

  1. 最小化影響原則
    • 避免使用定位屬性
    • 定位屬性從大容器平級(jí)分離為私有小容器
  2. 不犯二準(zhǔn)則
    • 對(duì)于非浮層元素,避免設(shè)置 z-index 值滓技,靈活應(yīng)用層疊順序哩牍、后來(lái)居上棚潦、層疊上下文等技巧令漂。
    • z-index 值沒(méi)有任何道理需要超過(guò)2
  3. 組件層級(jí)計(jì)數(shù)器
    • 通過(guò)js獲取body下子元素的最大z-index值
  4. 可訪(fǎng)問(wèn)性隱藏
    • 利用z-index負(fù)值元素在層疊上下文的背景之上,其它元素之下丸边,達(dá)到隱藏不可見(jiàn)效果叠必。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市妹窖,隨后出現(xiàn)的幾起案子纬朝,更是在濱河造成了極大的恐慌,老刑警劉巖骄呼,帶你破解...
    沈念sama閱讀 216,470評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件共苛,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡蜓萄,警方通過(guò)查閱死者的電腦和手機(jī)隅茎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)嫉沽,“玉大人辟犀,你說(shuō)我怎么就攤上這事〕袼叮” “怎么了堂竟?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,577評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)玻佩。 經(jīng)常有香客問(wèn)我出嘹,道長(zhǎng),這世上最難降的妖魔是什么咬崔? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,176評(píng)論 1 292
  • 正文 為了忘掉前任税稼,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘娶聘。我一直安慰自己闻镶,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,189評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布丸升。 她就那樣靜靜地躺著铆农,像睡著了一般。 火紅的嫁衣襯著肌膚如雪狡耻。 梳的紋絲不亂的頭發(fā)上墩剖,一...
    開(kāi)封第一講書(shū)人閱讀 51,155評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音夷狰,去河邊找鬼岭皂。 笑死,一個(gè)胖子當(dāng)著我的面吹牛沼头,可吹牛的內(nèi)容都是我干的爷绘。 我是一名探鬼主播,決...
    沈念sama閱讀 40,041評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼进倍,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼土至!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起猾昆,我...
    開(kāi)封第一講書(shū)人閱讀 38,903評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤陶因,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后垂蜗,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體楷扬,經(jīng)...
    沈念sama閱讀 45,319評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,539評(píng)論 2 332
  • 正文 我和宋清朗相戀三年贴见,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了烘苹。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,703評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蝇刀,死狀恐怖螟加,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情吞琐,我是刑警寧澤捆探,帶...
    沈念sama閱讀 35,417評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站站粟,受9級(jí)特大地震影響黍图,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜奴烙,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,013評(píng)論 3 325
  • 文/蒙蒙 一助被、第九天 我趴在偏房一處隱蔽的房頂上張望剖张。 院中可真熱鬧,春花似錦揩环、人聲如沸搔弄。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,664評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)顾犹。三九已至,卻和暖如春褒墨,著一層夾襖步出監(jiān)牢的瞬間炫刷,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,818評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工郁妈, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留浑玛,地道東北人昼伴。 一個(gè)月前我還...
    沈念sama閱讀 47,711評(píng)論 2 368
  • 正文 我出身青樓刃泌,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親靡狞。 傳聞我的和親對(duì)象是個(gè)殘疾皇子剧腻,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,601評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容

  • 1.z-index基礎(chǔ) z-index屬性指定了元素及其子元素的[z順序]拘央,而[z順序]可以決定當(dāng)元素發(fā)生覆蓋的時(shí)...
    徐國(guó)軍_plus閱讀 6,355評(píng)論 1 6
  • 問(wèn)答題47 /72 常見(jiàn)瀏覽器兼容性問(wèn)題與解決方案? 參考答案 (1)瀏覽器兼容問(wèn)題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)...
    _Yfling閱讀 13,748評(píng)論 1 92
  • 第一節(jié):z-index基礎(chǔ) 較大的z-index會(huì)覆蓋較小的那個(gè)z-index元素 z-index:auto 默認(rèn)...
    胖魚(yú)尾巴閱讀 1,008評(píng)論 0 0
  • 1.z-index簡(jiǎn)介 (1) 概念 z-index屬性指定了元素與元素之間的z軸上的順序书在,而z軸決定元素之間發(fā)生...
    Bennt閱讀 23,952評(píng)論 2 10
  • 接著昨天的話(huà)題。 又一次給醫(yī)生打電話(huà)叫醫(yī)生來(lái)看看拆又,妹妹也著急了說(shuō):弟弟回不來(lái)儒旬,叫出租車(chē)吧。弟弟打電話(huà)說(shuō):到家了帖族。我...
    感恩自然閱讀 217評(píng)論 2 1