層疊上下文和層疊順序

引自:張鑫旭的博客
本文地址:http://www.zhangxinxu.com/wordpress/?p=5115

前言

原文是在前面對transform引起的z-index“失效”探究過程中找到的,非常棒,所以轉(zhuǎn)載分享。本文大多摘自原文,進(jìn)行了壓縮,也加入了我自己的理解,希望對大家有幫助。

默認(rèn)情況下,網(wǎng)頁內(nèi)容是沒有偏移角的垂直視覺呈現(xiàn),當(dāng)內(nèi)容發(fā)生層疊的時候,一定會有一個前后的層疊順序產(chǎn)生。

我們大家可能都熟悉CSS中的z-index屬性,需要跟大家講的是,z-index實際上只是CSS層疊上下文和層疊順序中的一葉小舟。

一、什么是層疊上下文

層疊上下文,英文稱作“stacking context”。是HTML中的一個三維的概念。如果一個元素含有層疊上下文,我們可以理解為這個元素在z軸上“高人一等”。

z軸
表示的是用戶與屏幕的這條看不見的垂直線:

具象化
擁有層疊上下文的元素相當(dāng)于是一個容器,容器里裝著其他元素。
不同容器內(nèi)的元素的高低由容器決定。容器里面的元素,有高低之分,但不會突破容器。

二、什么是層疊水平

“層疊水平”英文稱作”stacking level”,決定了同一個層疊上下文中元素在z軸上的顯示順序。

就跟人一樣,網(wǎng)頁中的元素雖然都是獨(dú)立個體,但是總有一個類似的排名排序的情況存在。這個就是層疊水平。層疊上下文的層疊水平是優(yōu)先級更高的層疊水平。

普通元素的層疊水平優(yōu)先由層疊上下文決定,因此,層疊水平的比較只有在當(dāng)前層疊上下文元素中才有意義。

注意:千萬不要把層疊水平和z-index屬性混為一談。某些情況下z-index確實可以影響層疊水平,但是,只限于定位元素以及flex盒子的子元素,而層疊水平所有的元素都存在。

三、什么是層疊順序

“層疊順序”英文稱作”stacking order”,表示元素發(fā)生層疊時的垂直顯示順序。層疊上下文和層疊水平是概念,而這里的層疊順序是規(guī)則。

在CSS2.1的年代,在CSS3還沒有出現(xiàn)的時候(注意這里的前提),層疊順序規(guī)則遵循下面這張圖:


這樣的設(shè)計是由元素的重要性出發(fā)的,內(nèi)容優(yōu)于布局,布局優(yōu)于裝飾

注意

  1. 這是css2的時候
  2. 這里的z-index: 0 只是表示一個0級別,對應(yīng)的是z-index: auto,沒有創(chuàng)建層疊上下文的級別

四、層疊準(zhǔn)則

層疊領(lǐng)域的黃金準(zhǔn)則。當(dāng)元素發(fā)生層疊的時候,其覆蓋關(guān)系遵循下面2個準(zhǔn)則:

  • 誰大誰上
    當(dāng)具有明顯的層疊水平標(biāo)示的時候,如識別的z-indx值,在同一個層疊上下文領(lǐng)域,層疊水平值大的那一個覆蓋小的那一個。

  • 后來居上
    當(dāng)元素的層疊水平一致、層疊順序相同的時候,在DOM流中處于后面的元素會覆蓋前面的元素。

五、層疊上下文的特性

層疊上下文元素有如下特性:

  • 層疊上下文的層疊水平要比普通元素高;
  • 層疊上下文可以阻斷元素的混合模式;
  • 層疊上下文可以嵌套,內(nèi)部層疊上下文及其所有子元素均受制于外部的層疊上下文;
  • 每個層疊上下文和兄弟元素獨(dú)立,也就是當(dāng)進(jìn)行層疊變化或渲染的時候,只需要考慮后代元素;
  • 每個層疊上下文是自成體系的,當(dāng)元素發(fā)生層疊的時候,整個元素被認(rèn)為是在父層疊上下文的層疊順序中。

六、層疊上下文的創(chuàng)建

層疊上下文基本是由一些特定的css屬性所創(chuàng)建,主要分為三種:

1. 根層疊上下文

頁面根元素,也就是滾動條的默認(rèn)的始作俑者<html>元素。這就是為什么,絕對定位元素在left/top等值定位的時候,如果沒有其他定位元素限制,會相對瀏覽器窗口定位的原因。

2. 定位元素與傳統(tǒng)層疊上下文

  • 設(shè)置position:relative/position:absolutez-index值不是auto的定位元素
  • 設(shè)置position:fixed的定位元素,z-index為任意

3. CSS3與新時代的層疊上下文

  • 設(shè)置了z-index,且不為auto的flex元素(父元素display:flex|inline-flex)
  • 設(shè)置了opacity,且不為1的元素
  • 設(shè)置了transform,且不為none的元素
  • 設(shè)置了mix-blend-mode值,且不為normal的元素
  • **設(shè)置了isolation,且為isolate的元素
  • 設(shè)置了filter值,且不是none的元素
  • will-change指定的屬性值為上面任意一個
  • 設(shè)置了-webkit-overflow-scrolling,且為touch的元素

七、層疊上下文與層疊順序

最終的層疊順序分兩種情況討論:

    1. 層疊上下文不依賴z-index數(shù)值,其層疊順序是z-index: auto,就是z-index: 0的級別,沒有創(chuàng)建層疊上下文的元素的級別
    1. 層疊上下文依賴z-index數(shù)值,則由z-index決定
      也就是兩個層疊準(zhǔn)則的詳細(xì)解釋,第一個:后來者居上,第二個:誰大誰上。

參考

張鑫旭的博文:
CSS3混合模式mix-blend-mode/background-blend-mode簡介
理解CSS3 isolation: isolate的表現(xiàn)和作用
使用CSS3 will-change提高頁面滾動、動畫等渲染性能

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,117評論 6 537
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,860評論 3 423
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,128評論 0 381
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,291評論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 72,025評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,421評論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,477評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,642評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,177評論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,970評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,157評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,717評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,410評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,821評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,053評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,896評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 48,157評論 2 375

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