【H5/CSS】簡單瞭解選擇器的優先順序

来源:https://www.cnblogs.com/PaturNax/archive/2022/08/06/16556965.html
-Advertisement-
Play Games

樣式的衝突 當我們通過不同的選擇器,選中相同的元素,並且為相同的樣式設置不同的值時,此時就發生了樣式的衝突。 案例一:使用類選擇器與元素選擇器選中同一元素,設置不同顏色 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> ...


樣式的衝突

  • 當我們通過不同的選擇器,選中相同的元素,並且為相同的樣式設置不同的值時,此時就發生了樣式的衝突。

案例一:使用類選擇器與元素選擇器選中同一元素,設置不同顏色

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<title>Document</title>
		<style>
			.red {
				color: red;
			}

			div {
				color: yellowgreen;
			}
		</style>
	</head>
	<body>
		<div class="red">我是一個div</div>
	</body>
</html>

可以看到紅色優先

選擇器的權重

這是因為發生樣式衝突時,應用哪個樣式由選擇器的權重(優先順序)決定,誰前面位數越前,則誰越優先,可以看到類選擇器優於元素選擇器。

選擇器 權重
內聯樣式 1,0,0,0
id選擇器 0,1,0,0
類和偽類選擇器 0,0,1,0
元素選擇器 0,0,0,1
通配選擇器 0,0,0,0
繼承的樣式 沒有優先順序

比較優先順序時,需要將所有的選擇器的優先順序進行相加計算,最後優先順序越高,則越優先顯示(分組選擇器是單獨計算的),說白就是看誰寫得越長,就越優先。

案例二:元素與id選擇器進行複合,跟只使用id選擇器比較

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<title>Document</title>
		<style>
			#box1 {
				background-color: orange;
			}

			div#box1 {
				background-color: yellow;
			}
		</style>
	</head>
	<body>
		<div id="box1">我是一個div</div>
	</body>
</html>

註意點:

選擇器的累加不會超過其最大的數量級,比如類選擇器再高(有11個)也不會超過id選擇器

案例三:同一個選擇器優先順序比較

如果同一個選擇器優先順序計算後相同,此時則優先使用靠下的style樣式

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<title>Document</title>
		<style>
			.box2 {
				background-color: yellow;
			}

			.box1 {
				background-color: orange;
			}
		</style>
	</head>
	<body>
		<div class="box1 box2">我是一個div</div>
	</body>
</html>

使用!important

可以在某一個樣式的後邊添加 !important ,則此時該樣式會獲取到最高的優先順序,甚至超過內聯樣式,但是在開發中這個玩意一定要慎用!因為一旦確定好優先順序,就不方便更改

.box2 {
    background-color: yellow !important;
}

.box1 {
    background-color: orange;
}

參考

視頻鏈接(P39)
尚矽谷Web前端零基礎入門HTML5+CSS3基礎教程丨初學者從入門到精通


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

-Advertisement-
Play Games
更多相關文章
  • 1、await和.result/ .getwaiter() .getresult()的區別 await:Task.Run裡面的邏輯是新開的線程去執行的,await Task.Run後面邏輯都在新開的線程去執行。 private async void MainWindow_Loaded(object ...
  • 在智慧工廠領域,智慧城市領域,都需要對設備進行監控。比如工廠需要對周圍環境溫度、濕度、氣壓、電壓,燈的開關進行監控。這時候就需要物聯網平臺來進行管理。 在智慧工廠領域,寶馬集團通過英偉達的Omniverse平臺在電腦中創建數字孿生工廠,併在數字孿生工廠中進行改變生產線配置、工人動線、倉儲管理等實驗 ...
  • 前言 在進行某些爬蟲任務的時候,我們經常會遇到僅用Http協議難以攻破的情況,比如協議中帶有加密參數,破解需要花費大量時間,那這時候就會用Selenium去模擬瀏覽器進行頁面上的元素抓取 大多數情況下我們用Selenium只是爬取一下頁面上可見的元素信息或者做一些模擬人工的操作,但頁面可見元素的數據 ...
  • 需求背景: 近日,在安裝某軟體過程,發現在安裝過程需要輸入一些信息才能繼續下一步操作,在機器數量較少情況下,我們可以單台登錄上去完成安裝操作,但當機器數量超過一定時,如果再手動登錄操作,就會產生大量重覆性操作,既不能帶來有效學習能力提升,同時也會極大產生不確定性,引發工作效率下降,那麼如何自動化完成 ...
  • getIRC-Best IRC Client for mac是一款實用的IRC客戶端,它由各種獨立的 IRC 伺服器網路(或“網路”)組成,這些機器允許用戶連接到 IRC。 詳情:getIRC-Best IRC Client for mac(IRC客戶端) 簡單介紹 macOS 上的 Interne ...
  • 有人相愛,有人夜裡開車看海,我是leetcode第一題都做不出來 題目 給定一個整數數組 nums 和一個整數目標值 target,請你在該數組中找出 和為目標值 target 的那 兩個 整數,並返回它們的數組下標。 你可以假設每種輸入只會對應一個答案。但是,數組中同一個元素在答案里不能重覆出現。 ...
  • Vue3 使用v-md-editor如何動態上傳圖片了 前端代碼: <v-md-editor :autofocus="true" v-model="blog.content" height="510px" placeholder="請輸入內容" left-toolbar="undo redo cle ...
  • 該案例主要是實現的功能有:添加商品功能,將商品添加到購物車的功能還有將商品刪除功能,還有就是移出購物車的功能 該案例實現的難點是將商品添加到購物車列表的時候 數量的增加,當購物車有該商品的時候就進行累加操作,沒有該商品就賦值為1. 上代碼: <!DOCTYPE html> <html lang="e ...
一周排行
    -Advertisement-
    Play Games
  • 概述:本文代碼示例演示瞭如何在WPF中使用LiveCharts庫創建動態條形圖。通過創建數據模型、ViewModel和在XAML中使用`CartesianChart`控制項,你可以輕鬆實現圖表的數據綁定和動態更新。我將通過清晰的步驟指南包括詳細的中文註釋,幫助你快速理解並應用這一功能。 先上效果: 在 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • 概述:本示例演示了在WPF應用程式中實現多語言支持的詳細步驟。通過資源字典和數據綁定,以及使用語言管理器類,應用程式能夠在運行時動態切換語言。這種方法使得多語言支持更加靈活,便於維護,同時提供清晰的代碼結構。 在WPF中實現多語言的一種常見方法是使用資源字典和數據綁定。以下是一個詳細的步驟和示例源代 ...
  • 描述(做一個簡單的記錄): 事件(event)的本質是一個委托;(聲明一個事件: public event TestDelegate eventTest;) 委托(delegate)可以理解為一個符合某種簽名的方法類型;比如:TestDelegate委托的返回數據類型為string,參數為 int和 ...
  • 1、AOT適合場景 Aot適合工具類型的項目使用,優點禁止反編 ,第一次啟動快,業務型項目或者反射多的項目不適合用AOT AOT更新記錄: 實實在在經過實踐的AOT ORM 5.1.4.117 +支持AOT 5.1.4.123 +支持CodeFirst和非同步方法 5.1.4.129-preview1 ...
  • 總說周知,UWP 是運行在沙盒裡面的,所有許可權都有嚴格限制,和沙盒外交互也需要特殊的通道,所以從根本杜絕了 UWP 毒瘤的存在。但是實際上 UWP 只是一個應用模型,本身是沒有什麼許可權管理的,許可權管理全靠 App Container 沙盒控制,如果我們脫離了這個沙盒,UWP 就會放飛自我了。那麼有沒... ...
  • 目錄條款17:讓介面容易被正確使用,不易被誤用(Make interfaces easy to use correctly and hard to use incorrectly)限制類型和值規定能做和不能做的事提供行為一致的介面條款19:設計class猶如設計type(Treat class de ...
  • title: 從零開始:Django項目的創建與配置指南 date: 2024/5/2 18:29:33 updated: 2024/5/2 18:29:33 categories: 後端開發 tags: Django WebDev Python ORM Security Deployment Op ...
  • 1、BOM對象 BOM:Broswer object model,即瀏覽器提供我們開發者在javascript用於操作瀏覽器的對象。 1.1、window對象 視窗方法 // BOM Browser object model 瀏覽器對象模型 // js中最大的一個對象.整個瀏覽器視窗出現的所有東西都 ...