CSS深入理解學習筆記之z-index

来源:http://www.cnblogs.com/tinyTea/archive/2017/07/19/7201520.html
-Advertisement-
Play Games

1、z-index基礎 z-index含義:指定了元素及其子元素的”z順序“,而”z順序“可以決定元素的覆蓋順序。z-index值越大越在上面。 z-index值:auto(預設值);integer(整數值);inherit(繼承)。 z-index基本特性:①支持負值;②支持CSS3 animat ...


1、z-index基礎

  z-index含義:指定了元素及其子元素的”z順序“,而”z順序“可以決定元素的覆蓋順序。z-index值越大越在上面。

  z-index值:auto(預設值);integer(整數值);inherit(繼承)。

  z-index基本特性:①支持負值;②支持CSS3 animation動畫;③在CSS2.1時代,需要和定位元素配合使用。

2、z-index與定位元素

  z-index值越大越在上面。

  如果定位元素z-index發生嵌套:祖先優先原則,前提是祖先的z-index值是數值,不是auto

3、層疊上下文與層疊水平

  層疊上下文:是HTML元素中的一個三維概念,表示元素在z軸上的層疊表現。

  具有層疊上下文的元素:①頁面根元素天生具有層疊上下文,稱之為”根層疊上下文“;②z-index值為數值的定位元素也具有層疊上下文;③其他屬性

  層疊水平:層疊上下文的每個元素都有一個層疊水平,決定了同一個層疊上下文中元素在z軸上的顯示順序。遵循“後來居上”和“誰大誰上”的層疊準則。層疊水平和z-index不是同一個東西,普通元素也有層疊水平。

  層疊上下文特性:①層疊上下文可以嵌套,組合成一個分層次的層疊上下文;②每個層疊上下文和兄弟元素獨立,當進行層疊變化或渲染的時候,只需要考慮後代元素;③每個層疊上下文是自成體系的,當元素的內容被層疊後,整個元素被認為是在父層的層疊順序中。

4、層疊順序

  含義:元素髮生層疊時候有著特定的垂直顯示順序。

  著名的7階層疊水平:

  

5、z-index與層疊上下文

  ⑴ 從層疊順序上講,定位元素預設z-index:auto可以看成是z-index:0,但是從層疊上下文來講,兩者卻有著本質的差異;

  ⑵ z-index不為auto的元素會創建層疊上下文;

  ⑶ z-index層疊順序的比較止步於父級層疊上下文。

  為何定位元素會覆蓋普通元素:具有定位屬性的元素,z-index值為auto可以看為0,z-index:auto的層疊順序>inline水平盒子。

  z-index與創建層疊上下文:z-index不是auto的情況下,元素會創建層疊上下文。(IE8+)

  z-index受限於層疊上下文:父元素z-index為數值的情況下,會優先展現層疊順序。

6、其他屬性與層疊上下文

  其他參與層疊上下文的屬性:①z-index值不為auto的flex項(父元素display:flex|inline-flex);②元素的opacity值不是1;③元素的transform值不是none;④元素mix-blend-mode值不是normal;⑤元素的filter值不是none;⑥元素的isolation值是isolate;⑦position:fix聲明;⑧will-change指定的屬性值為上面任意一個;⑨元素的-webkit-overflow-scrolling設為touch。

7、z-index與其他屬性層疊上下文

  不支持z-index的層疊上下文元素的層疊順序均是z-index:auto級別:

  

  依賴z-index的層疊上下文的層疊順序卻決於z-index值。

8、z-index相關實踐分享

  最小化影響原則:

  

  不犯二準則:

  

  組件層級計數器:

  

  通過JS獲得body下子元素的最大z-index值。

  負值z-index與可訪問性隱藏:

    可訪問性隱藏:人肉眼不可見,但是輔助設備可以識別。

    


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前面的話 本文將詳細介紹MongoDB安全相關的內容 概述 MongoDB安全主要包括以下4個方面 1、物理隔離 系統不論設計的多麼完善,在實施過程中,總會存在一些漏洞。如果能夠把不安全的使用方與MongoDB資料庫做物理上的隔離,即通過任何手段都不能連接到資料庫,這是最安全的防護。但,通常這是不現 ...
  • 寫在前面的話: 最近一波H5廣告火爆整個互聯網圈,身為圈內人,我們怎能 不! 知!道! :( 噓!真不知道的也繼續看下去,有收穫 ↓ ) So,搞懂這個並不難。 這篇文章將帶你從頭到尾瞭解H5廣告的實現。 本文主要講一下幾個關鍵點 一、視頻內聯播放。 -- 想要營造一種文字與視頻混排的現象,視頻不要 ...
  • Proxy var engineer = { name: 'Joe Sixpack', salary: 50 }; var interceptor = { set: function (receiver, property, value) { console.log(property, 'is ch ...
  • (1)檢查node版本 在安裝vue的環境之前,安裝NodeJS環境是必須的。可以使用node -v指令檢查,需要保證安裝了4.0版本以上的nodeJS環境。 當然,沒有安裝的話,去Node.js的官網下載一下,各種下一步,傻瓜式安裝就好,非常方便。 tips:這裡說一下我自己踩過的一個坑,我最開始 ...
  • 1、下載地址:https://github.com/kartik-v/bootstrap-fileinput/ 打開壓縮包中的example/index.html查看示例。根據示例的代碼選擇需要的控制項代碼使用。 2、需要結合bootstrap使用,即頁面需要引入bootstrap相關js和css文件 ...
  • 代碼下載:https://github.com/lima-helen/vue-click-link 解決辦法有很多,之前也有看到同學用的是跳轉到空白頁,然後再跳路由以達到監控路由的目的; 這裡的解決辦法是: 在bottom.vue中接收並wath 該數值以達到不同數值為不同的狀態 ...
  • for迴圈裡面的break;和continue;語句 break語句 哇,我已經找到我要的答案了,我不需要進行更多的迴圈了! 比如,尋找第一個能被5整除的數: for迴圈中,如果遇見了break語句,這個for迴圈就會立即終止,不在進行其他的迭代了。 for(var i = 1 ; i <= 100 ...
  • 事件的預設傳播機制: 捕獲階段:從外向里依次查找元素 目標階段:從當前事件源本身的操作 冒泡階段:從內到外依次觸發相關的行為(我們最常用的就是冒泡階段) 具體見下圖: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...