你真的瞭解CSS繼承嗎?看完必跪

来源:https://www.cnblogs.com/lyy-1/archive/2020/06/16/13139228.html
-Advertisement-
Play Games

也許你瞧不起以前的 css ,但是你不該再輕視眼下的 css 。近年來 css 的變數系統已逐步得到各大瀏覽器廠商支持,自定義選擇器等強勢襲來,嵌套系統/模塊系統也在路上…為了更好的掌握 css 這門語言,很有必要把之前零零散散的 css 知識回爐重造下。 css 作為一門語言而,也有其繼承原理,雖 ...


也許你瞧不起以前的 css ,但是你不該再輕視眼下的 css 。近年來 css 的變數系統已逐步得到各大瀏覽器廠商支持,自定義選擇器等強勢襲來,嵌套系統/模塊系統也在路上…為了更好的掌握 css 這門語言,很有必要把之前零零散散的 css 知識回爐重造下。

css 作為一門語言而,也有其繼承原理,雖然簡單,你卻未必掌握。

屬性的是否預設繼承
初始值是指當屬性沒有指定值時的預設值,如這些語句的值都是預設值:background-color: transparent、left: auto 、float: none、width: auto 等。

css 的繼承很簡單,分為預設繼承的和預設不繼承的,但所有屬性都可以通過設置 inherit 實現繼承。

當沒有指定值時,預設繼承的屬性取父元素的同屬性的計算值(相當於設置了 inherit ),預設不繼承的屬性取屬性的初始值(時相當於設置了 initial )。

預設繼承的 (“Inherited: Yes”) 的屬性:
所有元素預設繼承:visibility、cursor
內聯元素預設繼承:letter-spacing、word-spacing、white-space、line-height、color、font、 font-family、font-size、font-style、font-variant、font-weight、text- decoration、text-transform、direction
塊狀元素預設繼承:text-indent、text-align
列表元素預設繼承:list-style、list-style-type、list-style-position、list-style-image
表格元素預設繼承:border-collapse
預設不繼承的(“Inherited: No”) 的屬性:
文本屬性預設不繼承:vertical-align、text-decoration、text-shadow、white-space、unicode-bidi
盒子屬性預設不繼承:display、width、height、padding、margin、border、min-width、min-height、max-width、max-height、overflow、clip
背景屬性預設不繼承:background、background-color、background-image、background-repeat、background-position、background-attachment
定位屬性預設不繼承:float、clear、position、top、right、bottom、left、z-index
內容屬性預設不繼承:content、counter-reset、counter-increment
輪廓屬性預設不繼承:outline-style、outline-width、outline-color、outline
頁面屬性預設不繼承:size、page-break-before、page-break-after
聲音屬性預設不繼承:pause-before、pause-after、pause、cue-before、cue-after、cue、play-during
可以看到涉及到文本相關的屬性,都是預設繼承的,畢竟 css 設計之初就是為了更好的在網頁上呈現文字。

需要註意的是,部分屬性的預設值是會根據元素的 display 屬性的值而計算的,比如 vertical-align 屬性,如果是 display: inline 元素,則其計算值為基線對齊 vertical-align: baseline ,如果是 display: inline-block 元素,則其計算值為 vertical-align: bottom 。

通用屬性值 initial、inherit 和 unset
css 為控制繼承提供了四個特殊的通用屬性值(屬性 revert 只有很少的瀏覽器支持,所以實際上是三個),每個 css 屬性都能使用這些值。

inherit
設置該屬性會使子元素屬性和父元素相同。實際上,就是“開啟繼承”。

initial
將屬性的初始值應用於元素。實際上,就是“重置為預設值”。

unset
將屬性重置為自然值,也就是如果屬性是自然繼承的那麼就是 inherit ,否則和 initial 一樣。

實例
這些通用屬性值可以有很多妙用,舉個慄子:

利用 inherit 實現如下圖片倒影:

div::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    bottom: -100%;
    background-image: inherit; // 背景圖片繼承,這一般人想不到吧...
    transform: rotateX(180deg);
}
這是我創建的web前端開發學習q裙 851231348  分享學習的方法和需要註意的小細節,不停更新最新的教程和學習方法

  

  1. 利用 initial 重置 left 為預設值 auto
    div {
      position: absolute;
      left: 20px;
      top: 20px;
    }
    div + div {
      left: initial;
      right: 20px;
    }

 

 

例子中 div 設置過了 left ,div2 的 right 若要生效,須將 left 重置為初始值 initial (或者 unset )。

  1. 利用 unset 將屬性重置為未設置之前的值:

 

 例子中 p 標簽的 color 是預設繼承屬性,所以此時 color: unset 相當於 color: inherit 。 p 標簽的 border 屬性是預設不繼承屬性,所以此時 border: unset 相當於 border: initial 。

.unset {
  border: unset;
  color: unset;
}

  

總結

css 的繼承真的很簡單,只需要記住那些預設繼承的,剩下的都是預設不繼承的。而預設繼承的元素除了文本相關的哪些,只有 visibility、cursor 比較常用了,也是比較容易記得的。






 


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

-Advertisement-
Play Games
更多相關文章
  • 前端早早聊大會,前端成長的新起點,與掘金聯合舉辦。 本文 是前端早早聊的第 45 位講師 ,也是第六屆 - Serverless 專場,來自閑魚前端團隊的丹俠的分享 - 講稿簡要整理版(完整版含演示請看錄播視頻和 PPT): 概述 今天給大家分享一下閑魚如何在現有產品中落地 FaaS,希望我們的實踐 ...
  • readyState document.readyState 返回當前文檔的狀態 屬性如下: uninitialized 還未開始載入 loading 載入中 interactive 已載入,文檔與用戶可以開始交互 complete 載入完成 DOMContentLoaded 當 DOMConten ...
  • 幾天前一個小伙伴問我 Object.getOwnPropertyNames() 是乾什麼用的 平時還真沒有使用到這個方法,一時不知如何回答 從方法名稱來分析,應該是返回的是對象自身屬性名組成的數組 那和 Object.keys() 方法不就一樣了嗎 感覺事情並不這麼簡單,於是我仔細看了一下這幾種遍歷 ...
  • 在平時的開發過程中,父子 / 兄弟組件間的通信是肯定會遇到的啦,所以這裡總結了 6 種 Vue 組件的通信props / $e$emit / Vuex$attrs / $listeners $parent / $children 與 ref provide / inject 前言 如上圖所示,A/B ...
  • 只要接觸過前端,都會指導web前端的知識主要由三部分組成:分別為靜態html,樣式css,動態javascript(簡稱js)這三大部分組成。其三部分組成的一個體系的複雜程度不亞於其他一門技術的複雜程度。當然對於跟我一樣厲害的那些web前端來說那就是小菜一碟,但是很多人都只學了錶面,基礎部分,很多重 ...
  • 在日常開發中,項目中的菜單欄都是已經實現好了的。如果需要添加新的菜單,只需要在`路由配置`中新增一條路由,就可以實現菜單的添加。 相信大家和我一樣,有時候會躍躍欲試自己去實現一個菜單欄。那今天我就將自己實現的菜單欄的整個思路和代碼分享給大家。 ...
  • 1.let 和 const 命令 在es5時,只有兩種變數聲明,var 和function。在es6中新增了四種let和const,以及另外兩種聲明import和class。 我們先講解let和const,後續會補充import和class (1)let 我們先來看基本語法 { let a = 10 ...
  • 目錄: 1.擴展運算符2.Array.form()3.Array.of()4.數組實例的copyWithin()5.數組實例的find()和findIndex()6.數組實例的fill()7.數組實例的entries(),keys(),vlaues()8.數組實例的includes()9.數組的空位 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...