CSS基礎 - 選擇器備忘錄 --筆記5

目錄

  • 基礎選擇器
  • 組合器
  • 偽類選擇器
  • 屬性選擇器

選擇器可以選中頁面上的特定元素并為其指定樣式。
CSS有多種選擇器。

基礎選擇器

  • 標簽選擇器 – tagname:匹配目標元素的標簽名。優先級是0,0,1。如:p、h1、div
  • 類選擇器 – .class:匹配class屬性中有指定類名的元素。優先級是0,1,0。如:.media、.menu
  • ID選擇器 – #id:匹配擁有指定ID屬性的元素。優先級是1,0,0。如:#container
  • 通用選擇器 – *:匹配所有元素。優先級是0,0,0。

組合器

組合器是將多個基礎選擇器連接起來組成一個復雜選擇器。

  • 后代組合器:兩個基礎選擇器之間的空格,最常見的組合器。如 .nav-menu li
  • 子組合器(>):匹配的目標元素是其他元素的直接后代。如 .parent > .child
  • 相鄰兄弟組合器(+):匹配的目標元素緊跟在其他元素后面。如 p + h2
  • 通用兄弟組合器(~):匹配所有跟隨在指定元素之后的兄弟元素。注意,它不會選中目標元素之前的兄弟元素。如 li.active ~ li
  • 復合選擇器:多個基礎選擇器可以連起來組成一個復合選擇器。如 h1.page-header。注意:復合選擇器選中的元素將匹配其全部基礎選擇器。例如,.dropdown.is-active能夠選中

偽類選擇器

偽類選擇器用于選中處于某個特定狀態的元素。可能是由于用戶交互,也可能是由于元素相對于其父級或兄弟元素的位置。偽類選擇器始終以一個冒號(:)開始。優先級等于一個類選擇器(0,1,0)。

  • :first-child – 匹配的元素是其父元素的第一個子元素。

  • :last-child – 匹配的元素是其父元素的最后一個子元素。

  • :nth-child(an+b) – 匹配的元素在兄弟元素中間有特定的位置。

  • :nth-last-child(an+b) – 類似于:nth-child(),但不是從第一個元素往后數,而是從最后一個元素往前數。

  • :first-of-type – 類似于:first-child,但不是根據在全部子元素中的位置查找元素,而是根據擁有相同標簽名的子元素中的數字順序查找第一個元素。

  • :last-of-type – 匹配每種類型的最后一個子元素。

  • nth-last-of-type(an+b) – 根據元素類型以及特定公式選擇元素,從其中最后一個元素往前算,類似于:nth-last-child。

  • :not() – 匹配的元素不匹配括號內的選擇器。括號內的選擇器必須是基礎選擇器,它只能指定元素本身,無法用于排除祖先元素,同時不允許包含另一個排除選擇器。

  • :focus – 匹配通過鼠標點擊、觸摸屏幕或者按Tab鍵導航而獲得焦點的元素。

  • :hover – 匹配鼠標指針正懸停在其上方的元素。

  • :root – 匹配文檔根元素。對HTML來說,這是元素,還可以應用到XML或者類似于XML的文檔上,比如SVG。

  • :disabled – 匹配已禁用的元素,包括input、select以及button元素。

  • :enabled – 匹配已啟用的元素,即那些能夠被激活或者接受焦點的元素。

  • :checked – 匹配已經針對選定的復選框、單選按鈕或選擇框選項。

  • :invalid – 根據輸入類型中的定義,匹配有非法輸入值的元素。

  • :valid – 匹配有合法值的元素。

  • :required – 匹配設置了required屬性的元素。

  • :optional – 匹配沒有設置required屬性的元素。
    #偽元素選擇器
    偽元素類似于偽類,但是它不匹配特定狀態的元素,而是匹配在文檔中沒有直接對應HTML元素的特定部分。
    偽元素選擇器可能只匹配元素的一部分,甚至向HTML標記中未定義的地方插入內容。

  • ::before – 創建一個偽元素,使其成為匹配元素的第一個子元素。該元素默認是行內元素,可用于插入文字、圖片或其他形狀。必須指定content屬性才能讓元素出現,例如:.menu::before。

  • ::after – 創建一個偽元素,使其成為匹配元素的最后一個子元素。該元素默認是行內元素,可用于插入文字、圖片或其他形狀。必須指定content屬性才能讓元素出現,例如:.menu::after。

屬性選擇器

屬性選擇器用于根據HTML屬性匹配元素。其優先級與一個類選擇器(0,1,0)相等。

  • [attr] – 匹配的元素擁有指定屬性attr,無論屬性值是什么,例如:input[disabled]?。
  • [attr=“value”] – 匹配的元素擁有指定屬性attr,且屬性值等于指定的字符串值,例如:input[type=“radio”]?。
  • [attr^=“value”] – “開頭”屬性選擇器。
  • [attr$=“value”] – “結尾”屬性選擇器。
  • [attr*=“value”] – “包含”屬性選擇器。
  • [attr~=“value”] – “空格分隔的列表”屬性選擇器。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/98028.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/98028.shtml
英文地址,請注明出處:http://en.pswp.cn/web/98028.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

自動駕駛中的傳感器技術46——Radar(7)

衛星雷達(又稱為分布式雷達)主要講當前雷達的雷達信號處理計算以及雷達目標相關的一些感知算法都遷移到中央域控進行,雷達端基本只負責數據采集,這樣做的影響如下: 雷達端成本與功耗降低; 雷達端采樣得到的…

【論文閱讀】Diff-Privacy: Diffusion-based Face Privacy Protection

基于擴散模型的人臉隱私保護方法——DiffPrivacy,解決了兩類人臉隱私任務:匿名化(anonymization)和視覺身份信息隱藏(visual identity information hiding)。1. 研究背景隨著人工智能和大數據技術的普及&am…

React 原理篇 - 深入理解虛擬 DOM

一、什么是虛擬 DOM? 在前端開發中,“虛擬 DOM” 是一個高頻出現的術語,尤其在 React 生態中被廣泛討論。但很多開發者對它的理解往往停留在 “JS 對象” 這個表層認知上。 實際上,虛擬 DOM 是一種編程概念—— 在這個概念里&…

對匯編的初理解

此處是一個簡單的函數,里面將調用了一個函數add()函數這里是函數的原型這里是調用lcd函數產生的匯編語言,翻譯過來就是r11,r0cnt(r4cnt,前文有提及),然后調用add函數,此處BL是指會回到指令的下一…

《Python 自動化實戰:從零構建一個文件同步工具》

《Python 自動化實戰:從零構建一個文件同步工具》 一、開篇引入:為什么我們需要文件同步? 你是否有過這樣的困擾: 公司電腦和家里電腦上都有工作項目,每次更新都要手動復制? U 盤頻繁傳輸文件,不僅麻煩還容易出錯? 項目文件夾動輒幾 G,每次同步都耗時長、效率低? 在…

工業相機與鏡頭的靶面尺寸詳解:選型避坑指南

在機器視覺系統中,相機與鏡頭的靶面尺寸匹配是一個非常關鍵卻又經常被忽略的細節。選錯了,不但影響圖像質量,還可能導致畫面“黑角”、視野不符、鏡頭浪費等問題。 今天我們就用通俗易懂的方式,聊一聊相機與鏡頭靶面尺寸的那些事兒…

使用 Go 和 go-commons 實現內存指標采集并對接 Prometheus

文章目錄一、準備工作二、編寫內存采集代碼三、運行 Exporter四、接入 Prometheus五、可擴展思路總結在運維和監控領域,資源指標采集 是必不可少的一環。CPU、內存、磁盤、網絡這些系統資源,需要實時采集并上報到監控系統中。 本文以 內存指標采集 為例&…

webrtc弱網-IntervalBudget類源碼分析與算法原理

一、核心功能 IntervalBudget 類用于基于時間窗口的帶寬預算管理。它根據設定的目標比特率(kbps)和一個固定時間窗口(500ms),計算在該時間窗口內可用的字節數(即“預算”),并支持預…

深度學習基本模塊:RNN 循環神經網絡

循環神經網絡(RNN)是一種專門用于處理序列數據的神經網絡架構。與處理空間數據的卷積神經網絡(Conv2D)不同,RNN通過引入循環連接使網絡具有"記憶"能力,能夠利用之前的信息來影響當前的輸出&#…

React18學習筆記(二) React的狀態管理工具--Redux,案例--移動端外賣平臺

文章目錄一.Redux的基礎用法1.示例:普通網頁中的Redux計步器2.Redux管理數據的流程3.配套工具和環境準備3.1.配套工具3.2.環境準備4.示例:React項目中的Redux計步器思路步驟step1:創建子模塊step2:導入子模塊step3:注入store實例step4:React組件內使用store中的數據step5:在組件…

34.Socket編程(UDP)(上)

點分十進制字符串IP 轉 32位網絡序列IP 分析:1)IP轉成4字節 2)4字節轉成網絡序列 思路: "192.168.1.1" 進行字符串劃分,以 "." 為分割符,分割出"192",&qu…

Redis的持久化工具包—RDB AOF

文章目錄 前言 一、RDB 持久化(快照持久化) 1. 定義 2. RDB 觸發機制 (1)手動觸發 (2)自動觸發 3. RDB 持久化流程 4. RDB 核心配置 5. RDB 優缺點 二、AOF 持久化(日志持久化) 1. 定…

【Web安全】XXL-JOB框架SRC高頻漏洞分析總結

文章目錄前言一、核心漏洞分類與技術細節二、漏洞關聯利用與攻擊路徑三、版本演進與修復策略四、安全運維建議五、典型漏洞復現環境搭建六、總結前言 XXL-JOB是國內主流的開源分布式任務調度框架,由徐雪里開發維護,以輕量易用、高可用、適配分布式場景等…

Capacitor 打包后接口訪問不到的排查經歷

我最近在用 Quasar Capacitor 6 做一個 Android App,前端用的是 Vue3 Quasar,打包交給 Capacitor 去跑在手機的 WebView 里,后端是 FastAPI 提供接口。開發模式下一切順利,瀏覽器里訪問接口沒有任何問題,我甚至覺得打…

【正點原子】Linux應用編程入門~概念及環境介紹

應用編程概念 應用編程(也可稱為系統編程)與驅動編程、裸機編程有何不同?系統調用;何為庫函數;應用程序的 main()函數;應用程序開發環境的介紹;系統調用 定義系統調用(system call&a…

一、HTML 完全指南:從零開始構建網頁

文章目錄前言一、 HTML 結構認識 HTML 標簽HTML 文件基本結構標簽層次結構快速生成代碼框架二、 HTML 常見標簽詳解2.1 注釋標簽2.2 標題標簽 (h1 - h6)2.3 段落標簽 (p)2.4 換行標簽 (br)2.5 格式化標簽2.6 圖片標簽 (img)2.7 超鏈接標簽 (a)2.8 表格標簽基本使用合并單元格2.…

基于POI-TL實現動態Word模板的數據填充:【散點圖】特殊處理方案

基于POI-TL實現動態Word模板的數據填充:散點圖特殊處理方案 在使用POI-TL進行Word模板動態數據填充時,圖表生成是一個常見需求。最近在項目中使用POI-TL處理散點圖時遇到了一個特殊問題,經過研究后找到了解決方案,特此記錄分享。 問題背景 POI-TL作為一款優秀的Java Wor…

使用node-Express框架寫一個學校宿舍管理系統練習項目-前后端分離

今天繼續分享一個新的練習項目,是使用node做為后端語言,來寫的一個前后端分離項目:學校宿舍管理系統。我們如果想掌握一門編程語言,就是需要大量的練習。所以當我們學習到了一些知識,自己想一下 可以拿學到的知識&…

Kafka 運維實戰基本操作含命令與最佳實踐

1. 基礎概覽與工具入口 Kafka 發行包的所有 CLI 工具均在 bin/ 目錄下。任何工具不帶參數運行都會顯示所有可用選項。本文命令默認:--bootstrap-server localhost:9092;生產請替換為你的控制面或內網 VIP。 2. 主題管理(創建 / 修改 / 刪除 /…

貪心算法應用:航班起降問題詳解

Java中的貪心算法應用:航班起降問題詳解 貪心算法是一種在每一步選擇中都采取當前狀態下最優的選擇,從而希望導致全局最優解的算法策略。在航班起降問題中,貪心算法可以有效地解決機場跑道調度問題,即如何安排航班的起降順序以最大…