精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

抖音一面:Z-index大的元素一定在小的上面嗎?

開發 前端
層疊上下文和z-index兩個概念是分不開的。一個層疊上下文是由許多擁有z-index屬性元素形成的平面構成的;有z-index屬性的元素又會形成一個子層疊上下文。

大家好,我是年年!開始文章前,上兩道面試真題:

  1. z-index值大的元素一定在值小的上面嗎?
  2. 如何實現父元素覆蓋子元素?

先公布一下答案:z-index不一定會生效,生效了也不一定是值大的在上面,主要取決于層疊上下文;給父元素設置一個很大的z-index不能實現覆蓋子元素,但是把子元素的z-index設置成負數卻可以滿足要求。

這兩個題的考點都是層疊上下文,本文會講清為什么。

顧名不難思義,層疊上下文是把元素以三維的視角,放在不同層級來判斷最后的堆疊關系,它由z-index這個屬性來決定“等級“。

如何讓z-index生效

z-index是用于規定元素在z軸的高度,其值越大,離用戶越近,越在“上面”。

使用時可能會感覺這個屬性不太聽話:給元素設置的z-index好像沒有生效,它沒有按照預期跑到其他元素上面。因為它單獨使用時不生效,一定要配合定位屬性一起,即只對指定了position屬性的元素生效——只要不是默認值static,其他的absolute、relative、fixed都可以使z-index生效。

如圖1所示,在粉色的父元素下有有兩個絕對定位的子元素1和2,兩個子元素都沒有設置z-index,通過top/left屬性控制他們的位置,讓他們發生重疊,可以看到2在1的上面。因為兩者都沒有設置z-index,其層疊等級都可以看作是0,同級的元素會根據其在HTML中的出現順序出現順序決定堆疊結果。

如果我們希望1在2的上面,如圖2所示,可以給元素1加上z-index:1,而沒有指定z-index的元素2的z-index依舊可以當作0對待,按照大小關系,元素1在元素2上面了。

目前為止,都沒什么難度,不過是大小比較而已。但很多時候會發現,層疊結果只用單純的數值大小解釋不了:

如圖3所示,粉色背景下有兩個子元素1和2,2中有一個子元素3。三個元素都是絕對定位,其中元素3的z-index值最大,但是卻被壓在元素1下面了。

稍微修改一下,只把2號元素的的z-index去掉。如圖4所示,元素3又跑上來,蓋在1號、2號元素上面了。

要想搞懂這些問題,需要了解層疊上下文。

什么是層疊上下文

層疊上下文聽起來比較抽象,你可以把它想象成一個三維空間,這個空間內有很多個平面。

最大的層疊上下文就是由文檔根元素——html形成的:它自身連同它的子元素就形成了一個最大的層疊上下文,也就是說,我們寫的所有代碼都是在根層疊上下文里的。

層疊上下文包含多個平面,具體來說:每個z-index的值形成一個平面,普通的無定位的塊級元素也是一個平面,浮動元素也是一個平面,正是這些平面形成了層疊上下文。

除此之外,每個有z-index數值的元素也會連同它的子元素一起,生成一個小的層疊上下文,這個小層疊上下文和父級一樣,擁有多個平面。

去處理這些上下文時,我們可以按照從小到大的順序遞歸:先把最小的堆疊上下文中元素的順序理好,拍成一片——當做一個整體,再與父級的堆疊上下文中其他元素比較。

不知道你有沒有見過小吃街上的甲骨文仙貝:在一個大的壓片的鍋里放上面糊,在面糊上放上一個小蝦,最后合上蓋子夾緊,變成扁扁的一小片,可以清晰的看到上面蝦的樣子。

(截圖自網絡)

這個用來壓片的鍋就是層疊上下文,面糊、蝦就是不同層級的html元素。他們在被壓扁之前按照明確的上下順序擺放,但最后都會形成薄薄的一片小餅干。這片小餅干可以被放進一個更大的鍋里,和其他的食材,一起作為原料,繼續做成一片大餅干,但在大鍋眼里,這片小餅干誕生時是面糊在上還是蝦子在上,根本不重要,因為現在它是一個整體,只有討論這片小餅干在第二口鍋中,與其他食材的擺放順序才有意義。記住在這個模型,層級判斷就很簡單了。

我們在面對一些難以判斷的層級關系時,可以整理出一棵“層疊上下文樹”,有點類似于dom樹的結構。從小到大,把一個層疊上下文的內的不同平面的元素堆疊好,拍平,再放到父級的堆疊上下文樹中。

下面會用幾個例子加深理解,都附有在線鏈接,可以先點進去看看,試試自己能否解釋最后的呈現結果:

demo1

其中DOM的層級關系如下:

container1:absolute:

  • 1號:absolute z-index: 1
  • 2號:absolute z-index: 2

container2:absolute:

  • 3號:absolute z-index: 3

container1和container2雖然都是絕對定位,但是沒有設置z-index,不形成層疊上下文。所以只有根元素形成的這一個。

1、2、3號元素當然也形成了層疊上下文,但是沒有子元素,所以不討論,后面的例子也一樣

形成的層疊上下文樹如下:

根層疊上下文:

  • 1號:absolute z-index: 1
  • 2號:absolute z-index: 2
  • 3號:absolute z-index: 3

最后的層疊關系不難判斷,從下到上是1號-2號-3號

demo2

在demo1基礎上稍加修改,給container1、container2加上z-index,現在DOM的層級關系變為:

container1:absolute z-index: 4。

  • 1號:absolute z-index: 1
  • 2號:absolute z-index: 2

container2:absolute z-index: 1。

  • 3號:absolute z-index: 3

container1和container2都設置了z-index,加上根元素形成的層疊上下文,一共是三個。

形成的層疊上下文樹如下:

根層疊上下文:

  • 3號:absolute z-index: 3
  • 1號:absolute z-index: 1
  • 2號:absolute z-index: 2
  • container1:absolute z-index: 4
  • container2:absolute z-index: 1

先看container1形成的層疊上下文,此時不管它本身的z-index是多少,形成層疊上下文的元素,都在當前這個上下文的底部,再是1號元素、2號。

然后是container2形成的層疊上下文,只有一個3號元素,沒什么好說。

最后是根層疊上下文,它眼中container1和container2是一個整體,container2在下,container1在上。

所以最后的順序從下到上是:container2(3號)-container1(1號-2號)。

demo3

之前的container在視覺上看不到,現在給它一個顏色。container2的z-index設置為0,現在DOM的層級關系變為:

container1:absolute

  • 1號:absolute z-index: 2

container2:absolute z-index: 0

  • 2號:absolute z-index:-1

現在可以看到,從下到上分別是container1-container2-2號-1號。

這個例子比較難理解了,用層疊上下文樹分析一下,一共有兩個層疊上下文,一個是根元素形成的,另一個是container2。

根層疊上下文:

  • 2號:absolute z-index:-1
  • container1:absolute
  • 1號:absolute z-index: 2
  • container2:absolute z-index: 0

在container2形成的層疊上下文中,只有一個元素2,即使他的z-index是負數,也會放在container2之上,之前也說過,形成層疊上下文的元素在當前層疊上下文中總是最底下的。我們把他們兩個拍平,合成一個整體。

在根層疊上下文中,有container1、container2和1號三個元素。container1沒有設置z-index,可以看作0,和container2層級相同,當層級相同時,按照在html中出現的先后順序決定,所以是container1-container2;1號的層級最高,所以最后的層級是container1-container2-1號。

最后把container2中的其他元素展開,得到最后的層疊關系container1-container2(2號)-1號。

層疊上下文規律

通過這三個例子應該能清楚感受到什么是層疊上下文了,總結一下他的規律:

只有明確指定了z-index的值(不是auto)的定位元素才會生產一個層疊上下文,在這個層疊上下文中,內部元素層級都在它之上,哪怕是負數。

如果是一個沒有指定z-index(即為auto)的定位元素,那么雖然它不能形成一個層疊上下文,但是比較層級時,和z-index:0的等級是一樣的。

如果把浮動元素也放進來,我們可以得到一個完整的層疊等級:

這個圖看起來復雜,其實不用背,可以一個個來看:

  1. 首先看塊級元素,我們寫的大部分代碼都是它,比如div,我們能看到它們,就是因為塊級元素是在層疊上下文根元素之上的。
  2. 接著是浮動元素和文字,而浮動本身是為了實現環繞效果的,所以是浮動元素和文字是同一級,這樣才不會遮擋。
  3. 然后是定位元素,我們知道,不指定z-index,即為auto時,是會在浮動元素之上的,在層級關系中其實相當于0;可以繼續推出,z-index>0的會在z-index=0之上。
  4. 唯一要特意記憶的是z-index<0,他的層級關系是在塊元素之下,形成層疊上下文的根元素之上的。

其中,當多個層疊等級相同的元素重疊時,按照html中出現的順序決定堆疊上下關系,后出現的在上面。

CSS3的新特性

除了被定位的z-index元素,CSS3還提供另外的方法能生成一個層疊上下文。

特別偏門的不列舉了,意義不大,開發中可能會用到的有:

  1. 彈性布局的子項(父元素display:flex|inline-flex),并且z-index不是auto時。
  2. opacity非1的元素。
  3. transform非none的元素。
  4. filter非none的元素。

這些都能生成層疊上下文,flex子元素還可以使用z-index,近一步精確設置層級,其余三個設置z-index不生效,但在比較層級關系是被當作z-index:0對待。

結語

層疊上下文和z-index兩個概念是分不開的。一個層疊上下文是由許多擁有z-index屬性元素形成的平面構成的;有z-index屬性的元素又會形成一個子層疊上下文。當然,這里的z-index必須是被有效設置的,在以前是指被定位的元素——position為absolute/relative等,現在它還可以是flex的子元素。

在比較復雜元素的層疊順序時,主要是要整理出一棵層疊上下文樹,一個元素的層疊等級只在當前這個層疊上下文中有意義。

回到開頭的兩個問題,答案也不難理解了。

  1. z-index大的元素不一定在小的元素之上。因為它不一定生效,通常需要是一個定位元素才生效,在CSS3之后,彈性元素的子元素也可以生效;在z-index生效之后,也不是單純的大小比較,因為這個數值只在當前的層疊上下文中才有意義。
  2. 要實現父元素覆蓋子元素,去給父元素設置一個很大的z-index是沒有用的。因為這樣他就成為一個層疊上下文的根元素了,無論子元素被如何設置都會在這個層疊上下文根元素之上。正確的解法是把子元素的z-index設置為負數,這樣父元素是一個塊級元素,z-index<0 的子元素會在塊級元素之下,就可以實現我們想要的效果。
責任編輯:姜華 來源: 前端私教年年
相關推薦

2022-08-18 17:44:25

HTTPS協議漏洞

2020-09-19 17:46:20

React Hooks開發函數

2009-07-30 14:38:36

云計算

2023-12-01 09:11:33

大數據數據庫

2011-12-23 09:43:15

開源開放

2011-12-22 20:53:40

Android

2020-12-28 12:36:11

css重疊順序

2020-12-29 05:28:55

Css前端Css z-index

2022-05-11 22:15:51

云計算云平臺

2023-10-14 17:49:25

Java存儲

2022-08-13 12:07:14

URLHTTP加密

2024-05-15 16:41:57

進程IO文件

2012-12-19 09:04:29

2025-04-01 08:40:00

HTTPRPC開發

2024-11-11 16:40:04

2025-04-15 08:00:00

Java開發服務網格

2020-07-13 23:22:02

物聯網電子技術

2013-05-07 10:06:20

2010-08-31 10:30:59

CSSpositionz-index

2025-07-15 03:00:00

點贊
收藏

51CTO技術棧公眾號

99久久999| 在线免费观看的av网站| 国产日韩欧美一区| 伊人久久免费视频| 亚洲天堂一区二区在线观看| missav|免费高清av在线看| 国产香蕉久久精品综合网| 91亚洲精品在线| 欧美三级一区二区三区| 天天综合一区| 亚洲男人av在线| 精品国产午夜福利在线观看| 日韩久久一区二区三区| 一区二区三区四区亚洲| 欧美在线3区| 欧洲成人一区二区三区| 欧美a一区二区| 国语自产在线不卡| 日韩一区二区不卡视频| 西野翔中文久久精品国产| 欧美一级黄色片| 日韩精品免费播放| 九九精品调教| 国产精品高潮久久久久无| 国内外成人免费视频| 国产一区二区三区四区视频| 噜噜噜久久亚洲精品国产品小说| 欧美成人免费在线视频| 日本黄色激情视频| 久草精品在线| 日韩精品日韩在线观看| 亚洲成a人无码| 国产人与zoxxxx另类91| 欧美视频一区二区| 午夜dv内射一区二区| 涩涩涩在线视频| 午夜精品免费在线观看| 日本香蕉视频在线观看| av在线播放国产| 国产精品美女视频| 视频一区免费观看| 国产黄在线播放| 久久综合色综合88| 久久久久久99| 超碰免费在线97| 久久高清免费| 中文在线资源观看视频网站免费不卡| 久久国产精品影院| 高潮久久久久久久久久久久久久| 日韩欧美精品在线| 992tv人人草| 日韩精品视频网址| 一区在线不卡| 制服丝袜亚洲精品中文字幕| 国产成人综合精品三级| 久久久久久com| 国产一级大片在线观看| 韩国一区二区三区在线观看| 色综合久久精品亚洲国产| 99视频只有精品| 国产精品vip| 久久久久久噜噜噜久久久精品| 久久久精品国产sm调教网站| 国产精品国码视频| 久久久这里只有精品视频| 久久高清免费视频| 久久精品日产第一区二区| 日韩美女在线看| 国产精品第6页| 久久精品久久精品| 亚洲最大的免费| 蜜桃av鲁一鲁一鲁一鲁俄罗斯的| 国产 欧美在线| 国产在线精品日韩| 国产午夜视频在线观看| 国产精品福利av | 麻豆一区二区麻豆免费观看| 精品视频久久久久久| 97人妻精品一区二区免费| 成人精品电影| 美日韩丰满少妇在线观看| 欧美日韩三级在线观看| 免费看的黄色欧美网站| 国产在线日韩在线| 亚洲国产日韩在线观看| 91色乱码一区二区三区| 亚洲区一区二区三区| 成人国产免费电影| 婷婷国产在线综合| 最新天堂中文在线| 波多野结衣一区二区三区免费视频| 日韩经典中文字幕| 精品国产视频在线观看| 99热免费精品| 成人h视频在线观看播放| 日韩专区第一页| 国产精品毛片久久久久久久| 18禁网站免费无遮挡无码中文| 成人18视频在线观看| 欧美成人性福生活免费看| 国产熟妇久久777777| 欧美精品二区| 国产精品日韩欧美| 少妇一区二区三区四区| 一区在线观看免费| 国产l精品国产亚洲区久久| 伊人久久综合网另类网站| 亚洲国产日韩欧美在线图片 | 麻豆av电影在线观看| 亚洲男同性视频| 99免费视频观看| 亚洲一区二区免费在线观看| 中文字幕日韩综合av| 国产精品午夜影院| 国产在线播放一区| 天天人人精品| 中文字幕乱码中文乱码51精品| 91精品欧美一区二区三区综合在| 人妻一区二区视频| 在线观看的日韩av| 亚洲自拍偷拍第一页| aaa日本高清在线播放免费观看| 性做久久久久久免费观看| 久久6免费视频| 精品国产网站| 日本高清不卡的在线| 日本免费不卡视频| 一区二区三区中文字幕电影| 91精品999| 成人精品中文字幕| 国产精国产精品| 欧美挠脚心网站| 欧美日韩国产精品一区二区三区四区 | 色爱综合区网| 日韩一区二区精品葵司在线 | 伊人成综合网| 成人午夜一级二级三级| 伊人免费在线| 欧美日韩视频在线观看一区二区三区 | 国产精品午夜久久| 精品日韩久久久| 波多野结衣一区| 国产精品日韩在线| 色多多视频在线观看| 欧美日韩国产精选| 亚洲av无一区二区三区| 久久国产精品72免费观看| 亚洲三区在线观看| 亚洲欧洲二区| 欧美精品一区在线播放| www.久久久久久| 亚洲香蕉伊在人在线观| 污污免费在线观看| 一区二区三区国产盗摄| 久久久久资源| 日韩高清成人| 自拍偷拍亚洲区| 国产精品日韩无码| 伊人夜夜躁av伊人久久| 亚洲天堂av网站| 一二三区精品| 日韩国产精品一区二区三区| 粉嫩91精品久久久久久久99蜜桃| 日韩在线观看精品| xxxx国产精品| 婷婷久久综合九色国产成人 | 国产精品电影一区| 在线播放麻豆| 日韩一级成人av| 日韩特黄一级片| 国产日韩欧美麻豆| 成人av毛片在线观看| 欧美网站在线| 久热国产精品视频一区二区三区| 向日葵视频成人app网址| 日韩在线观看你懂的| a在线观看视频| 欧美丝袜一区二区| 久久精品日韩无码| 国产成人在线电影| 红桃av在线播放| 97色伦图片97综合影院| 国产精品香蕉视屏| 成人高清一区| 久久久噜噜噜久久久| 国产一区二区影视| 日韩欧美在线观看一区二区三区| 青青操免费在线视频| 国产精品理论片在线观看| 男生和女生一起差差差视频| 国产九九精品| 国产树林野战在线播放| 日韩一级电影| 亚洲一区亚洲二区亚洲三区| 日韩av影片| 久久成人av网站| 天堂av在线7| 91精品国产色综合久久久蜜香臀| 免费在线观看黄网站| 一区精品在线播放| 国产又爽又黄无码无遮挡在线观看| 久久国产欧美日韩精品| 国产一区二区三区精彩视频| 婷婷亚洲五月| 日本一区二区三区视频在线播放| 欧美.com| 成人激情视频免费在线| 亚洲天堂一区二区| 久久免费视频网站| 欧美成人性生活视频| 精品视频久久久| 成人免费视频国产免费麻豆| 欧美日韩国产一二三| 日本高清不卡码| 亚洲成人av一区二区三区| 天天色影综合网| 中文字幕国产一区| 国产免费一区二区三区网站免费| 波多野洁衣一区| 巨乳女教师的诱惑| 久久精品免费看| 国产高清视频网站| 久久亚洲欧洲| 激情五月宗合网| 亚洲精品女人| 日本福利视频网站| 国产精品99一区二区三| 视频一区视频二区视频三区视频四区国产| 亚洲另类春色校园小说| 国内一区二区三区在线视频| 国产成人精品福利| av观看久久| 综合中文字幕| 国产精品三区四区| y111111国产精品久久久| 91精品黄色| 日韩亚洲精品在线观看| 成人精品视频在线| 高清不卡一区| 亚洲综合中文字幕在线观看| 精品一区二区三区中文字幕视频 | 国产精品二三区| 国产探花视频在线| 国产精品久久久久影院| 日本理论中文字幕| 中文字幕免费一区| 一级免费黄色录像| 亚洲免费看黄网站| 久草福利资源在线观看| 亚洲第一综合色| 午夜毛片在线观看| 欧美日韩一区二区在线播放| 免费污污视频在线观看| 91黄色小视频| 一区两区小视频| 91精品国产欧美一区二区成人| 国产三级按摩推拿按摩| 欧美成人一区二区三区片免费| 亚洲国产精品国自产拍久久| 亚洲国产成人精品一区二区| 精品影院一区| 久久九九热免费视频| 日韩少妇视频| 91成人在线视频| 午夜无码国产理论在线| 成人a在线视频| xxxx日韩| 亚洲v国产v在线观看| 一区二区日韩欧美| 可以看毛片的网址| 首页亚洲欧美制服丝腿| 一区二区在线免费看| 国产成人综合网| 泷泽萝拉在线播放| 国产精品久久国产精麻豆99网站| 激情综合五月网| 一本大道av伊人久久综合| 在线视频你懂得| 精品福利视频一区二区三区| 青青草视频在线观看| 日韩视频亚洲视频| 国产激情视频在线看| 国产精品日韩在线观看| 涩爱av色老久久精品偷偷鲁| 麻豆91av| 欧美日韩亚洲一区二区三区在线| 欧美a在线视频| 国产美女一区二区| 国产精品无码网站| 亚洲免费在线观看视频| 日本久久综合网| 日韩欧美一区二区视频| 美女欧美视频在线观看免费| 久久成人综合视频| 欧美特黄aaaaaaaa大片| 亚洲一区二区三区毛片| 美女毛片一区二区三区四区最新中文字幕亚洲| 亚洲一区二区精品在线| 99国产精品私拍| 中文字幕剧情在线观看| 久久久久久一二三区| 九九视频免费在线观看| 欧洲精品一区二区| 天天射天天色天天干| 久久亚洲精品小早川怜子66| 浪潮色综合久久天堂| 激情五月综合色婷婷一区二区| 亚洲va在线| 日本成人黄色网| 久久伊人中文字幕| 久久免费视频99| 337p亚洲精品色噜噜狠狠| 免费理论片在线观看播放老| 欧美激情手机在线视频 | 日本中文不卡| 国产精品久久久久久久久久妞妞 | 久久久久久**毛片大全| 国产在线拍揄自揄拍| 制服.丝袜.亚洲.中文.综合| 高清毛片在线看| 欧美亚洲在线视频| 久久精品色播| 人妻少妇精品久久| 国产精品自拍一区| 精品人妻伦九区久久aaa片| 欧美日韩五月天| 四虎久久免费| 国产精品美女免费视频| 国产一区二区在线| 激情五月开心婷婷| 久久综合狠狠综合久久综合88 | 在线xxxx| 99久久99久久| 午夜日韩激情| 精产国品一区二区三区| 亚洲欧美日本在线| jlzzjlzz亚洲女人18| 两个人的视频www国产精品| 亚洲成人1区| 精品国产无码在线| 国产一区二区三区四区五区入口| 免费看一级黄色| 欧美精品亚洲二区| 黄网站免费在线观看| 国产免费一区二区三区香蕉精| 精品日韩欧美一区| 奇米视频888| 亚洲欧美视频在线观看| av网站在线观看免费| 欧美日韩第一视频| 精品国产午夜肉伦伦影院| 日韩一级性生活片| 26uuu亚洲综合色欧美| 欧美一区免费看| 中文字幕欧美亚洲| 日本免费精品| 福利视频一二区| 久久久久久久网| 在线观看日韩一区二区| 久久久国产一区二区三区| 精品999日本久久久影院| 免费看日b视频| 9人人澡人人爽人人精品| 免费污污视频在线观看| 日韩最新在线视频| 日韩中文字幕一区二区高清99| 久操网在线观看| 久久久久99精品国产片| 亚洲综合免费视频| 欧美激情aaaa| 亚洲精品一级二级三级| 五月婷婷六月丁香激情| 一区二区三区日韩欧美| 色视频在线看| 成人午夜高潮视频| 亚洲午夜久久久久久尤物| 伊人网在线视频观看| 欧美美女黄视频| 漫画在线观看av| 中文字幕人成一区| 不卡视频一二三| 在线亚洲欧美日韩| 欧美激情综合色综合啪啪五月| 视频一区在线观看| 香蕉视频色在线观看| 黑人巨大精品欧美一区二区| 日本亚洲精品| 九九99玖玖| 国内久久精品视频| av资源免费观看| 久久福利网址导航| 国产区精品区| 人妻 丝袜美腿 中文字幕| 在线欧美日韩国产| heyzo高清国产精品| 亚洲一区二区精品在线| 久久综合久色欧美综合狠狠| 国产wwwxxx| 国产精品久久久久久久天堂| 亚洲精品偷拍|