css選擇器的優先順序問題

来源:http://www.cnblogs.com/z937741304/archive/2017/12/03/7967553.html
-Advertisement-
Play Games

當我們寫頁面的時候,不知道你會不會產生這樣的問題,為什麼我給他添加的這條樣式分明已經選擇到我要給的元素了,但是他的樣式並沒有生效,那是為什麼呢? 定義的屬性有衝突時,瀏覽器會選擇用那一套樣式呢,下麵來介紹一下選擇器的優先順序。 一、選擇器的優先順序排序 1. !important 在屬性後面寫上這條樣式 ...


  當我們寫頁面的時候,不知道你會不會產生這樣的問題,為什麼我給他添加的這條樣式分明已經選擇到我要給的元素了,但是他的樣式並沒有生效,那是為什麼呢?

  定義的屬性有衝突時,瀏覽器會選擇用那一套樣式呢,下麵來介紹一下選擇器的優先順序。

  一、選擇器的優先順序排序

  1.   !important

    在屬性後面寫上這條樣式,會覆蓋掉頁面上任何位置定義的元素的樣式。

  2.   行內樣式,在style屬性裡面寫的樣式。

  3.  id選擇器

  4. class選擇器

  5. 標簽選擇器

     6. 通配符選擇器

  7. 瀏覽器的自定義屬性和繼承

上面寫的這些排序的順序就是優先順序/權重的大小。 可以自己試一試比較一下他們的大小順序。

  二、複雜選擇器優先順序,後代選擇器優先順序多種情況。

    有時候當我們寫樣式的時候會用到好多個後代樣式,那麼優先順序的情況是什麼情況呢。來看幾個例子。

    我這裡舉的例子有點少,如果你在學習,你可以多自己寫幾個例子看看效果。

   1. id個數多的優先順序高

#box .head span{
    color:blue;
}
.box .head span{
    color:red;
}
//下麵span標簽的顏色是藍色的   <div class="box" id="box">     <div class="head">       <span>我的顏色</span>     </div>   </div>

    2.id個數相等的看class個數,class越多優先順序越高

//這個例子和題目不符,目的是為了讓你看一下,這個span標簽的樣式是紅色的。 
//雖然第三個樣式的class個數多,但是他這個樣式的span標簽的樣式是繼承的,看第一個的總結,他的優先順序是最低的。所以他沒有選中的優先順序高。
//這裡我就不寫了,自己在第三個樣式p的後面在寫上一個span標簽。你會發現他的樣式優先順序是最高的。
#box .head span{ color:blue; } #box .head span{ color:red; } #box .head .p{ color:deeppink; } <div class="box" id="box"> <div class="head"> <p class="p"><span>我的顏色</span></p> </div> </div>

  3.id和class個數相等,看元素個數,個數越多優先順序越高。

//顏色應用的是第一個的樣式,粉色
#box .head p span{   color:deeppink; } #box .head span{   color:blue; } #box .head span{   color:red; } <div class="box" id="box">   <div class="head">     <p class="p"><span>我的顏色</span></p>   </div> </div>

  4. 優先順序相同,後面的樣式會覆蓋前面的樣式, 不分先後順序,只看選擇器類型和個數。

//藍色,優先順序相同,後面的覆蓋前面的,id、class、元素的個數不分先後順序
#box .head p span{
	color:red;
}
#box div .p span{
	color:blue;
}

<div class="box" id="box">
	<div class="head" id="head">
		<p class="p" id="p"><span>我的顏色</span></p>
	</div>
</div>

  本來以為這一個內容會寫上好多內容,沒想到寫了這麼一點就完了,如果你通過這篇文章學到了一點知識和內容,那麼我會非常開心的。下周見(*^__^*) 。

 


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

-Advertisement-
Play Games
更多相關文章
  • File的知識 ...
  • 迭代器的方式會產生鎖定 伺服器端增加發送給每個客戶端已收到信息的功能 所以當獲取到一個socket,並打開它的線程進行迴圈接收客戶端發來信息時,我們把這個內部類的線程Client保存到集合List<Client>中 然後在讀取到客戶端信息後,把這個信息發送給所有埠 通過迴圈 for(int i=0 ...
  • import random help(random) FUNCTIONS betavariate(alpha, beta) method of Random instance # 隨機實例的方法 Beta distribution. # β分佈 Conditions on the parameter... ...
  • 策略模式(Strategy Pattern): 我的理解,將代碼中每個變化之處抽出,提煉成一個一個的介面或者抽象類,讓這些變化實現介面或繼承抽象類成為具體的變化類。再利用多態的功能,可將變化之處用介面或抽象類的對象代替,再用其子類為對象賦值,這樣就可以將對象隨時更換成具體的變化類。 枯燥的文字描述總 ...
  • 1.超炫酷HTML5 Canvas 3D旋轉地球動畫 這是一款基於HTML5 Canvas的3D地球模擬動畫,動畫以太空作為背景,地球在太空中旋轉,同時我們也可以拖拽滑鼠來從不同的角度觀察地球。另外我們也可以通過點擊全屏按鈕來全屏觀看地球旋轉動畫,記得在很早以前我們也分享過一款基於HTML5 Can ...
  • 合理的title、description、keywords:搜索對著三項的權重逐個減小,title值強調重點即可,重要關鍵詞出現不要超過2次,而且要靠前,不同頁面title要有所不同;description把頁面內容高度概括,長度合適,不可過分堆砌關鍵詞,不同頁面description有所不同;ke ...
  • 未曾料到被黑客勒索比特幣的戲碼竟然降臨到我的身上,幾個月的技術積累付之一炬。怪只怪自己學藝不精,心存僥幸和無知,不過經此一役,方知網路安全防護的重要性。 一直未給自己的mongodb資料庫設置賬號密碼,也沒禁止外網訪問,等同於在這個開放的網路世界里裸奔了幾個月,不被人惦記才怪呢。 昔人有雲:跌倒並不 ...
  • 1、網格設計 方法一、float(浮動) float 將4個div 從左至右排序,當外圍區塊小時,4個div會根據外圍的區塊寬度重新調整內容顯示的位置。 原理就是利用float:left將元素浮動靠左排列,反之用靠右排列,當超過容器最大寬度時,div就會自動擠到下一行。 方法二、display:in ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...