CSS選擇器詳解

来源:http://www.cnblogs.com/manongjc/archive/2016/02/23/5208861.html
-Advertisement-
Play Games

本文轉載:http://www.manongjc.com/article/517.html 選擇器是CSS的核心,從最初的元素、class/id選擇器,演進到偽元素、偽類,以及CSS3中提供的更豐富的選擇器,定位頁面上的任意元素開始變得愈發的簡單。 1、元素選擇器 這是最基本的CSS選擇器,HTML


本文轉載:http://www.manongjc.com/article/517.html

選擇器是CSS的核心,從最初的元素、class/id選擇器,演進到偽元素、偽類,以及CSS3中提供的更豐富的選擇器,定位頁面上的任意元素開始變得愈發的簡單。

 

1、元素選擇器

這是最基本的CSS選擇器,HTML文檔中的元素本身就是一個選擇器:

p {line-height:1.5em; margin-bottom:1em;}

 

2、關係選擇器

E F:後代選擇器,該選擇器定位元素E的後代中所有元素F:

ul li {margin-bottom:0.5em;}

E > F:子選擇器,該選擇器定位元素E的直接子元素中的所有元素F,它將忽略任何進一步的嵌套:

ul > li {list-style:none;} //僅限ul的直接子元素li,如果li裡面還嵌套著另一個 ul 結構時,最裡面的 li 將被忽略

E + F:相鄰兄弟選擇器,該選擇器定位與元素E具有相同父元素且在標記中緊鄰E的元素F:

li + li {border-top:1px solid #ddd;} //定位具有相同父元素ul里除第一個li之外的所有li

E ~ F:一般兄弟選擇器,該選擇器定位與元素E具有相同父元素且在標記中位於E之後的所有元素F:

h1 ~ p {color:#f00;} //定位具有相同父元素的,h1標簽之後的所有p標簽

 

3、屬性選擇器

E[attr]:該選擇器定位具有屬性attr的任何元素E:

input[required] {border:1px solid #f00;} //定位頁面里所有具有必填屬性"required"的input

E[attr=val]:該選擇器定位具有屬性attr且屬性值為val的任何元素E:

input[type=password] {border:1px solid #aaa;} //定位頁面里的密碼輸入框

E[attr|=avl]:該選擇器定位具有屬性attr且屬性值為val或以val-開始的任何元素E:

p[class|=a] {color:#333;} //定位頁面里所有的P段落里具有class屬性且屬性值為a或是a-開始的,比如class="a"以及class="a-b"

E[attr~=val]:該選擇器定位具有屬性attr且屬性值為完整單詞 val 的任何元素E:

div[title~=english] {color:#f88;} //定位頁面里所有具有屬性title且屬性值里擁有完整單詞english的div容器,比如title="english"以及title="a english"

E[attr^=val]:該選擇器定位具有屬性attr且屬性值以val開頭的任何元素E:

div[class^=a] {color:#666;} //定位頁面里具有屬性class且屬性值以a開頭的div容器,比如class="a"以及class="ab"

E[attr$=val]:該選擇器與E[attr^=val]正好相反,定位具有屬性attr且屬性值以val結尾的任何元素E:

div[class$=a] {color:#f00;} //定位頁面里具有屬性class且屬性值以a結尾的div視窗,比如class="nba"以及class="cba"

E[attr*=val]:該選擇器與E[attr~=val]相似,但更進一步,定位具有屬性attr且屬性值任意位置包含val的元素E,val可以是一個完整的單詞,也可以是一個單詞中的一部分:

a[title*=link] {text-decoration:underline;} //定位所有title里具有link字元串的a鏈接

 

4、偽類

:link:未訪問的鏈接;

:visited:已訪問的鏈接,不建議使用;

:hover:滑鼠移動到容器,不僅限於鏈接,可用於頁面中的任何元素;

:active:被激活時的狀態,不僅限於鏈接,可用於任何具有tabindex屬性的元素;

:focus:獲得焦點時狀態,不僅限於鏈接,可用於任何具有tabindex屬性的無線:

input:focus {border:1px solid #333;} //輸入框獲得焦點時的樣式

:enabled:已啟用的界面元素:

input:enabled {border:1px solid #899;}

:disabled:已禁用的界面元素:

input:disabled {background:#eee;}

:target:該選擇器定位當前活動頁面內定位點的目標元素:

#info:target {font-size:24px;} //當訪問的URL網址為 123.html#info 時,id="info"將載入這個字體樣式

:default:應用於一個或多個作為一組類似元素中的預設元素的UI元素;

:valid:應用於有效元素:

input:valid {border:1px solid #6a6;} //當輸入框驗證為有效時載入這個邊框樣式,基於type或pattern屬性

:invalid:應用於空的必填元素,以及未能與type或pattern屬性所定義的需求相匹配的元素:

input:invalid {border:1px solid #f00;} //當輸入框為空且必填時,或已填寫但驗證無效時,載入此邊框樣式

:in-range:應用於具有範圍限制的元素,其中該值位於限制內;比如具有min和max屬性的number和range輸入框;

out-of-range:與:in-range選擇相反,其中該值在限制範圍外;

:required:應用於具有必填屬性required的表單控制項;

optional:應用於沒有必填屬性required的所有表單控制項

:read-only:應用於其內容無法供用戶修改的元素;

:read-write:應用於其內容可供用戶修改的元素,比如輸入框;

:root:根元素,始終指html元素;

E F:nth-child(n):該選擇器定位元素E的第n個子元素的元素F:

div.class p:nth-child(3) {color:#f00;} //class="class"的div容器里的第3個元素p,如果第3個子元素不是p,此樣式將失效

E F:nth-last-child(n):該選擇器定位元素E的倒數第n個子元素的元素F;

E:nth-of-type(n):該選擇器定位元素E的第n個指定類型子元素;

E:nth-lash-of-type(n):該選擇器定位元素E的導數第n個指定類型子元素:

.class p:nth-child(2) 與 .class p:nth-of-type(2) 的區別在於,如果.class里的第2個子元素不是P元素時,.class p:nth-child(2) 的樣式將無效,而.class p:nth-of-type(2) 將定位在 .class 里的第2個p元素

nth-child(n)、nth-last-child(n)、nth-of-type(n)、nth-last-of-type(n),這其中的 n 可以使用數字靜態式,比如 .nth-child(2n+1) 將匹配第1、3、5...個元素

E:first-child:父元素的第一個子元素E,與:nth-child(1)相同;

E:last-child:父元素的倒數第一個子元素E;

E:first-of-type:與:nth-of-type(1)相同;

E:last-of-type:與:nth-last-of-type(1)相同;

E:only-child:父元素中唯一的子元素E;

E:only-of-type:父元素中唯一具有該類型的元素E;

E:empty:沒有子元素的元素,沒有子元素包括文本節點;

E:lang(en):具有使用雙字母縮寫(en)表示的語言的元素;

E:not(exception):該選擇器將選擇與括弧內的選擇器不匹配的元素:

p:not(.info) {font-size:12px;} //匹配所有class值不為info的p元素

 

5、偽元素

偽元素可用於定位文檔中包含的文本,為與偽類進行區分,偽元素使用雙冒號 :: 定義,但單冒號 : 也能被識別。

::first-line:匹配文本首行;

::first-letter:匹配文本首字母;

::before 與 ::after :使用 contnet 屬性生成額外的內容並插入在標記中:

a[href^=http]::after {content:"link"} //在頁面的a鏈接的後面插入文字link

::selection:匹配突出顯示的文本:

::selection {background:#444; color:#fff;} //定義選中的文本顏色與背景色

當然,如果要方便的使用這些強大的CSS選擇器的話,使用Chrome、Firefox之類的瀏覽器吧,最起碼得拋棄IE9以下的IE版本瀏覽器吧。


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

-Advertisement-
Play Games
更多相關文章
  • HttpServletRequest.getParameter("modelName"); 能取到想要的modelObject嗎?經過測試之後,發現是不能的。後來想想,其他道理挺簡單的,當兩個Web組件之間為轉發關係時,轉發源會將要共用 request範圍內的數據先用setAttribute將數據放
  • 定義 外觀模式(Facade),為子系統中的一組介面提供一個一致的界面,定義一個高層介面,這個介面使得這一子系統更加容易使用。 其實外觀模式,就已經比較容易理解了,舉個例子,你寫了個登陸系統,其實包含幾個步驟,首先驗證密碼,其次驗證用戶許可權,再其次查詢用戶的基礎信息,但是對於登陸的用戶來說,這些步驟
  • 1 package com.shejimoshi.structural.Composite.type1; 2 3 4 /** 5 * 功能:將對象組合成樹形結構以表示“部分-整體”的層次結構。composite使得用戶對單個對象和組合對象的使用具有一致性 6 * 適用:想表示對象的部分-整體層次結構
  • 定義 橋接模式(bridge):將抽象部分與實現部分分離,使它們都可以獨立的變化. 從定義來看,抽象的簡直看不了,那麼通俗點講,我們怎麼理解橋接模式呢? 我們再舉一個例子,假設你是一個地主,你有兩個管家,兩個工人,那麼每天你怎麼指揮他們呢,你可以告訴管家A讓工人1去幹活,同時也可以告訴管家B讓工人2
  • Atitit.跨語言系統服務管理器api相容設計 1. Common api,相容sc ,service control??1 1.1. 服務創建,use sc1 1.2. 服務delete ,use sc1 1.3. 服務start, net start1 1.4. Service stop, n
  • 前段時間一個項目因併發量大。因防止宕機做了主從備份,首頁的表連接查詢又非常的耗時。故此拿出利器Redis緩存這個查詢結果,並隨著用戶操作而更新。 因官方目前只有linux版,Windows版下載: https://github.com/ServiceStack/redis-windows/tree/
  • 軟體環境:jdk、tomcat、docker、centos、虛擬機 首先,您要準備一個 CentOS 的操作系統,虛擬機也行。總之,可以通過 Linux 客戶端工具訪問到 CentOS 操作系統就行。 需要說明的是,Ubuntu 或其它 Linux 操作系統也能玩 Docker,只不過本文選擇了以
  • 使用JDK的類 BASE64Decoder BASE64Encoder Java代碼 package test; import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder; /** * BASE64加密解密 */ public clas
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...