CSS 選擇器優先順序

来源:https://www.cnblogs.com/hazjblog/archive/2023/08/10/css-specificity-rules.html
-Advertisement-
Play Games

# CSS 選擇器權重 聲明:本文參考來源於[MDN CSS 優先順序](https://developer.mozilla.org/zh-CN/docs/Web/CSS/Specificity)(80%)和B站尚矽谷的[課程](https://m.bilibili.com/video/BV1p84y ...


CSS 選擇器權重

聲明:本文參考來源於MDN CSS 優先順序(80%)和B站尚矽谷的課程(20%)

我想你一定是來進行速查的,所以我會儘量精簡文章內容,保證不浪費時間,不說廢話

文章包括新的:is:where(實驗性)說明

優先順序:概念

優先順序就是分配給 CSS 聲明的一個權重,由 匹配的選擇器中的 每一種選擇器類型的 數值 決定。

多個 CSS 優先順序相等的時候,最後的那個選擇器將會被應用到元素上。

註意:文檔樹中元素的接近度對優先順序沒有影響。

速查:六點

  1. 格式:(1 | 0,a,b,c)
  • 1 | 0: 是否有!important
  • a: id的個數
  • b: .class :matix [key]的個數
  • c: el, ::el 的個數
  1. 衝突比較:從左到右,後來居上
  2. 簡記:
  • !imp > 行內 > id > .class > el > 通配符 > 繼承
  1. 如果有!imp,那麼即使是jsDOM也無法修改
  2. 提示:VSCode能自動計算權重
  3. 註意:
  • :not:is本身對優先順序沒有影響,但是,在 :not和is內部聲明的選擇器會影響優先順序
  • :where() 和其中的選擇器的優先順序是 0

比較:後來者居上,a>b>c

  1. 從左到右:a->b->c,從左到右比較
/* A選擇器:(0,2,3) */
:is(h1) div:nth-child(2n):not(p:selected)

/* B選擇器:(0,2,1) */
h1 div.headtext[needcolor]

/*
1. 0=0
2. 2=2
3. 3>1
4. A選擇器勝出
*/
  1. 後來居上:前面寫的被後來覆蓋(前提:後者優先順序>=前者)
<link href="foo.css">
<link href="bar.css">

<TodoList /> <!-- green -->
/* foo.css */
TodoList {
  color: red;
}
/* bar.css */
TodoList {
  color: green;
}
  1. 無影響者:通配選擇符(*)關係選擇符(+, >, ~, " ", ||)和 否定偽類:not()對優先順序沒有影響

!important:核彈級聲明

當在一個樣式聲明中使用它,此聲明將覆蓋任何其他聲明

無視:DOM樹

什麼意思?直接上代碼

body h1 {
  color: green;
}

/* 後來居上 */
html h1 {
  color: purple;
}

<html>
  <body>
    <h1>Here is a title!</h1>
  </body>
</html>

h1將被渲染成紫色。

其他:關於where選擇器

實驗性: 這是一項實驗性技術,在將其用於生產之前,請仔細檢查MDN瀏覽器相容性表格
給你康好了QAQ:

  • Chrome 88+
  • Firefox 78+
  • Safari 14+
  • IE ??? 早沒有了

工具:計算優先順序

如果你的編輯器沒有查看優先順序的功能

那麼這是一個網站,供你計算優先順序:Specificity Calculator

本文來自博客園,作者:DanicaStarrr,轉載請註明原文鏈接:https://www.cnblogs.com/hazjblog/p/css-specificity-rules.html


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

-Advertisement-
Play Games
更多相關文章
  • 1 pentaho簡介 `pentaho`是一款開源`ETL`工具,純java編寫的C/S模式的工具,可綠色免安裝,開箱即用。支持Windows、macOS、Linux平臺。 ...
  • 本文分享自華為雲社區《openGauss資料庫在CentOS上的安裝實踐》,作者:Gauss小松鼠 。 1.安裝前準備 安裝資料庫前先要有已安裝centOS 7.6的伺服器+資料庫安裝包。 首先找小伙伴申請了華為雲ECS伺服器安裝好了OS,這裡使用的是x86_64+centos。 華為雲伺服器現在可 ...
  • 根據 2023 年的 Stack Overflow 調研 (https://survey.stackoverflow.co/2023/) ,Postgres 已經取代 MySQL 成為最受敬仰和渴望 (the most admired, desired) 的資料庫。 隨著 Postgres 的發展勢 ...
  • 一、升級webview版本 (1). 下載需要更新的Webview apk。如果不能翻牆可以用下載好的版本(相容32/64位):Webview-115.0.5790.138 (2). 在路徑\aosp\external\chromium-webview\prebuilt\下替換arm或arm64架構 ...
  • # 前言 提到爬蟲可能大多都會想到python,其實爬蟲的實現並不限制任何語言。 下麵我們就使用js來實現,後端為express,前端為vue3。 # 實現功能 話不多說,先看結果: ![image](https://img2023.cnblogs.com/blog/1769804/202308/1 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 最近,我剛剛完成了一個閱讀器的txt文件閱讀功能,但在處理大文件時,遇到了文本內容過多導致瀏覽器崩潰的問題。 一般情況下,沒有任何樣式渲染時不會出現什麼問題,15MB的文件大約會有3秒的空白時間。 <div id="content"></ ...
  • ## css3 瀑布流佈局遇見截斷下一列展示後半截現象 - 註:css3實現瀑布流佈局簡直不要太香~~~~~ ## 場景-在uniapp項目中 ### 當瀑布流佈局column-grap:10px 相鄰兩列之間的間隙為10px,column-count:2,2列展示時,就出現了截斷問題,如下圖: ! ...
  • 7月27號下午2點 New 操作符做了什麼: 1. 創建一個新的空對象。 2. 將這個新對象的原型指向構造函數的原型。 3. 將構造函數的this指向這個新對象。 4. 根據構造函數返回類型作判斷,如果是值類型,返回newObj。如果是引用類型,就返回這個引用類型的對象 Vue2 數組push、sh ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...