CSS深入理解之z-index 筆記

z-index 與 css 定位屬性

z-index 只對定位元素有作用。

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

如果定位元素z-index沒有發生嵌套:

  • 后來居上;
  • 哪個值大哪個在上;

如果定位元素z-index發生嵌套:

  • 以祖先元素為標準(z-index不為auto)

css 中的層疊上下文和層疊等級

層疊上下文是HTML元素中的一個三維概念,表示元素在z軸上距離人眼更近。

具有層疊上下文的元素:

  • 頁面根元素天生具有層疊上下文,稱為“根層疊上下文”。
  • z-index 值為數值的定位元素具有層疊上下文。
  • 其它屬性

層疊上下文中的每個元素都有一個層疊等級,決定了同一個層疊上下文中元素在z軸上的顯示順序。遵循“后來居上”“誰值大誰在上”的層疊準則。

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

層疊等級是放在同一個層疊上下文中來進行比較的,不在同一個層疊上下文中沒有意義。

層疊上下文的特性

  • 層疊上下文可以嵌套,組合成一個分層次的層疊上下文。
  • 每個層疊上下文和兄弟元素獨立:當進行層疊變化或渲染時,只影響后代元素。
  • 每個層疊上下文是自成體系的:當元素的內容被層疊后,整個元素被認為是在父層的層疊順序中。

層疊順序

層疊順序表示元素發生層疊時特定的垂直顯示順序。

7階層疊等級(stacking level)

層疊等級的比較要在同一個層疊上下文中

看下面的例子:

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

z-index 與層疊上下文

  1. 定位元素默認z-index:auto可以看成是z-index:0

為何定位元素會覆蓋普通元素?

定位元素默認z-index:auto,根據層疊順序表z-index:auto是大于inline/inline-block的,所以定位后,就會覆蓋普通元素。

  1. z-index 不為 auto 的定位元素會創建層疊上下文;

從層疊順序上講,z-index:auto可以看成是z-index:0
但從層疊上下文來講,z-index:auto不會產生層疊上下文,z-index:0則會產生層疊上下文。

  1. z-index 層疊順序的比較止步于父級層疊上下文;

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

  1. z-index 值不為 auto 的子 flex 項(父元素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產生層疊上下文*/
}
.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 指定的屬性值為上面任意一個。
  1. 元素的-webkit-overflow-scrolling 設為 touch
    -webkit-overflow-scrolling 屬性控制元素在移動設備上是否使用滾動回彈效果.
  • auto 使用普通滾動, 當手指從觸摸屏上移開,滾動會立即停止。
  • touch 使用具有回彈效果的滾動, 當手指從觸摸屏上移開,內容會繼續保持一段時間的滾動效果。繼續滾動的速度和持續的時間和滾動手勢的強烈程度成正比。同時也會創建一個新的堆棧上下文。

z-index 與其它 css 屬性層疊上下文的關系

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

依賴z-index值創建層疊上下文的情況:

  • position 值為relative/absolutefixed(部分瀏覽器)。
  • display:flex|inline-flex容器的子flex項。

z-index 最佳實踐

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

推薦閱讀更多精彩內容

  • 1.z-index基礎 z-index屬性指定了元素及其子元素的[z順序],而[z順序]可以決定當元素發生覆蓋的時...
    徐國軍_plus閱讀 6,398評論 1 6
  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽默認的外補...
    _Yfling閱讀 13,777評論 1 92
  • 第一節:z-index基礎 較大的z-index會覆蓋較小的那個z-index元素 z-index:auto 默認...
    胖魚尾巴閱讀 1,033評論 0 0
  • 1.z-index簡介 (1) 概念 z-index屬性指定了元素與元素之間的z軸上的順序,而z軸決定元素之間發生...
    Bennt閱讀 24,005評論 2 10
  • 接著昨天的話題。 又一次給醫生打電話叫醫生來看看,妹妹也著急了說:弟弟回不來,叫出租車吧。弟弟打電話說:到家了。我...
    感恩自然閱讀 227評論 2 1