摘要:當?shù)诙拥娜萜骱凶由墳閷盈B上下文時,紅色盒子及灰色盒子的軸層級受制于第二層的容器盒子。當元素處于同一層疊上下文內時可按照如下規(guī)則進行層疊判斷。
本文首發(fā)于政采云前端團隊博客:CSS 層疊上下文(Stacking Context)
在網(wǎng)頁制作的過程中,元素與元素之間的位置關系,在坐標軸上一般可體現(xiàn)為 X 軸、Y 軸和 Z 軸。對于 X 軸和 Y 軸的定位大多數(shù)開發(fā)都能比較直觀的搞清楚,而 Z 軸 則相對較為模糊,或者說不能全面的理解Z軸的顯示邏輯。
大多數(shù)人都知道可以使用 position 屬性配合 z-index 屬性解決元素的 Z 軸顯示問題,對于更深層次的原理卻不太了解。本文主要介紹了層疊上下文、層疊等級、層疊順序等概念。目的就是為了理清元素的 Z 軸顯示順序的內部邏輯。
一、現(xiàn)象 Z 軸上的顯示順序// 穿透父級容器的 z-index
// 不能穿透父級容器的 z-index
兩段代碼基本一樣,只有在深藍色盒子處有個 z-index 不同。當父級容器的 z-index 為 auto 的時候,紅色盒子穿過了父級容器出現(xiàn)在了父級容器的背后(被父級容器遮擋住)。當父級容器的 z-index 為 0 的時候,紅色盒子無法穿過父級容器。
元素 Z 軸對比// 元素 Z 軸對比
// 元素 Z 軸對比
同樣的,以上兩段代碼基本一樣,都是有 3 層的 DIV 盒子。最外層是一個深藍色盒子,中間一層容器盒子,最下面一層紅色及灰色盒子。不同之處在于中間這層容器盒子的 z-index 由 auto 變成了 0。最底下的紅色及灰色盒子的 Z 軸層級比較的結果就截然不同。
由以上兩個例子我們可以發(fā)現(xiàn),當 z-index 為數(shù)值并且生效的時候,容器會發(fā)生一種變化,會使得容器內的子組件無法穿過容器本身,并且子組件的層級由父組件決定。這種變化后的容器元素我們稱之為層疊上下文。
二、特性層疊上下文有幾個特性
層疊上下文可以嵌套,內部層疊上下文及其所有子元素均受制于外部的層疊上下文。
這個好理解,可以參考例子 2 。當?shù)诙拥娜萜骱凶由墳閷盈B上下文時,紅色盒子及灰色盒子的 Z 軸層級受制于第二層的容器盒子。
每個層疊上下文和兄弟元素獨立,也就是當進行層疊變化或渲染的時候,只需要考慮后代元素。
這一條在性能優(yōu)化上可以用的上。在更新 DOM 元素的時候考慮上層疊上下文可以使得站點性能表現(xiàn)更加優(yōu)異。
層疊上下文未指定 z-index 時,其層疊等級與 z-index : 0 相同, 要比普通元素高。指定 z-index 時按照層疊規(guī)則來。
這條專門指的由 CSS3 屬性創(chuàng)建出來的層疊上下文,其本身未指定 z-index。其層疊等級應該是 z-index: 0。三、創(chuàng)建
層疊上下文大體上可分為三種創(chuàng)建方式
頁面根元素,稱為根層疊上下文
z-index 值為數(shù)值的定位元素的傳統(tǒng)層疊上下文
其他 CSS3 屬性(詳情可動手實驗了解)
z-index 值不為 auto 的 flex 項(父元素 display : flex | inline-flex )
元素的 opacity 值不是 1
元素的 transform 值不是 none
元素的 filter 值不是 none
其他
注意:四、兩個概念,層疊順序、層疊等級
1、z-index: auto 和 z-index: 0 在層疊等級上屬于同一級。但是 z-index: 0 就是符合這一條“z-index 為數(shù)值”會使得元素升級為層疊上下文。
2、IE6,7 有個不合常理的地方,就是當元素的 z-index 為 auto 的時候,該元素也升級為創(chuàng)建層疊上下文。這就是為什么在過去 IE6/IE7 的 z-index 一直是個老大難的原因。
在說層疊規(guī)則之前兩個概念需要大家了解一下,這有利于我們在日常交流中探討相關的問題。
層疊順序( Stacking Order ),這個其實就是很字面的意思,它表示元素發(fā)生層疊時按照特定的順序規(guī)則在 Z 軸上垂直顯示順序。
層疊等級( Stacking Level ),這個很好理解了。層疊等級就是個描述元素層疊順序的一個名詞,它決定了同一個層疊上下文中元素在 Z 軸上的顯示順序。舉個例子:A 元素與 B 元素重疊之后,A 元素在 B 元素上面。那么我們就可以直接說 A 元素的層疊等級大于 B 元素的層疊等級。
五、層疊規(guī)則當元素互相層疊的時候,顯示規(guī)則如下。
當互相層疊的元素都是層疊上下文元素,即明確的有 z-index 值的時候(沒有明確的 z-index 值的層疊上下文也就是 CSS3 創(chuàng)建的層疊上下文 z-index 值為0 )直接比較 z-index 的值,值大的處在值小的元素的上方。
當元素處于同一層疊上下文內時可按照如下規(guī)則進行層疊判斷。
當元素的層疊等級一致、層疊順序也相同的時候,在 DOM 流中處于后面的元素會覆蓋前面的元素。
參考文章深入理解 CSS 中的層疊上下文和層疊順序
層疊上下文
徹底搞懂 CSS 層疊上下文、層疊等級、層疊順序、z-index
招賢納士(Recruitment)招人,前端,隸屬政采云前端大團隊(ZooTeam),50 余個小伙伴正等你加入一起浪~ 如果你想改變一直被事折騰,希望開始能折騰事;如果你想改變一直被告誡需要多些想法,卻無從破局;如果你想改變你有能力去做成那個結果,卻不需要你;如果你想改變你想做成的事需要一個團隊去支撐,但沒你帶人的位置;如果你想改變既定的節(jié)奏,將會是“5年工作時間3年工作經(jīng)驗”;如果你想改變本來悟性不錯,但總是有那一層窗戶紙的模糊… 如果你相信相信的力量,相信平凡人能成就非凡事,相信能遇到更好的自己。如果你希望參與到隨著業(yè)務騰飛的過程,親手參與一個有著深入的業(yè)務理解、完善的技術體系、技術創(chuàng)造價值、影響力外溢的前端團隊的成長歷程,我覺得我們該聊聊。任何時間,等著你寫點什么,發(fā)給 ZooTeam@cai-inc.com
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/116363.html
摘要:與的映射關系為。與根對應的對應的層疊上下文,是其他的祖先,的范圍覆蓋整條。注意的默認值為,自動賦值為。對于,它會將賦予給對應的,而則不會。 一、前言 ?假如只是開發(fā)簡單的彈窗效果,懂得通過z-index來調整元素間的層疊關系就夠了。但要將多個彈窗間層疊關系給處理好,那么充分理解z-index背后的原理及兼容性問題就是必要的知識...
摘要:層疊上下文可以嵌套,內部層疊上下文及其所有子元素均受制于外部的層疊上下文。例當按以下設置,則出現(xiàn)紅色在綠色之上的效果。如何觸發(fā)觸發(fā)一個元素形成層疊上下文有以下方法,摘自根元素值不為的絕對相對定位一個值不為的項目,即父元素。 層疊上下文【stacking context】 對于stacking context,在MDN中的描述是 Stacking context is the three...
摘要:標簽中的一切都被置于這個默認的層疊上下文的一個層疊層上物品放在桌子上。在層疊上下文中,其子元素按照上面解釋的規(guī)則進行層疊。在中所有的盒模型元素都處于三維坐標系中。 最近在項目的過程中遇到了一個問題,menu-bar希望始終顯示在最上面,而在之后的元素都顯示在它之下,當時設置了 z-index 也沒有效果,不知道什么原因,因此找了一下css有關層疊方面的資料,解決了這個問題,這里記錄一下...
摘要:但該盒不建立新的層疊上下文,除非是根元素。以上是基于的層疊上下文介紹。同級情況下,按照二者在源代碼中的順序,居后的又重新占領高地了。現(xiàn)在我們看以下源代碼這個時候,以視口為包含塊進行定位和大小計算,將會鋪滿整個屏幕。 前言:關于層疊上下文,筆者還沒有去閱讀更詳細的 W3C 規(guī)范來了解更本質的原理(表打我,等我校招拿到 offer 了我就讀好伐 T_T)。一直聽說 CSS3 里的層疊上下文...
摘要:層疊上下文是中的一個三維的概念如果一個元素含有層疊上下文我們就可以理解為這個元素在軸上就高人一等軸表示用戶與屏幕之間并不存在的的垂直線通俗點講就是人眼看屏幕的視線這條垂直于屏幕的線擁有層疊上下文的元素包括頁面根元素天生具有層疊上下文稱之為根 stacking context 層疊上下文(stacking context)是HTML中的一個三維的概念.如果一個元素含有層疊上下文,我們就可...
閱讀 3010·2021-11-23 09:51
閱讀 3617·2021-10-13 09:39
閱讀 2505·2021-09-22 15:06
閱讀 888·2019-08-30 15:55
閱讀 3157·2019-08-30 15:44
閱讀 1787·2019-08-30 14:05
閱讀 3440·2019-08-29 15:24
閱讀 2372·2019-08-29 12:44