css3 偽類選擇器快速復(fù)習(xí)小結(jié)

前言
如果說 css 作為前端開發(fā)的基本功, 那么 "選擇器" 就是基礎(chǔ)中的基礎(chǔ). 如果你在復(fù)寫或者學(xué)習(xí)這些容易令人混淆的選擇器, 那么你就來對地方了, 我的老伙計(jì).
本篇文章會直接了當(dāng)?shù)谋容^它們的特性, 幫助你快速的掌握它們:
- first-child
- last-child
- first-of-type
- last-of-type
- only-child
- only-of-type
- nth-child
- nth-last-child
- nth-of-type
- nth-last-of-type
first-child & last-child
這兩個(gè)選擇器會匹配一組兄弟元素中的第一個(gè):
注意: 要想使得該選擇器起作用實(shí)際上需要滿足三個(gè)條件:
- 被前面的選擇器匹配 此例中是
p
- 是一組兄弟元素
- 是第一個(gè)(或者最后一個(gè))元素
last-child
在此不多贅述, 區(qū)別就是從后向前進(jìn)行匹配.
first-of-type & last-of-type
這兩個(gè)選擇器會匹配同一組類型中的第一個(gè)(最后一個(gè))而不理會該元素的位置是否真的是在該組元素的第一個(gè)(最后一個(gè)):
注意: 要想使得該選擇器起作用實(shí)際上需要滿足兩個(gè)條件:
- 被前面的選擇器匹配 此例中是
p
- 是一組兄弟元素
last-of-type
在此不多贅述, 區(qū)別就是從后向前進(jìn)行匹配.
only-child & only-of-type
only-child
匹配那些沒有兄弟元素的元素, 換句話說匹配那些 "孤兒" 元素:
上圖中被 "孤立" 的元素有第一個(gè) <p>
和嵌套的 <span>
它們都被選擇器匹配到了.
only-of-type
匹配一組兄弟元素中類型唯一類型的元素:
因?yàn)榈谝粋€(gè)<p>
和第二個(gè) <p>
以及最后的 <span>
在對應(yīng)的父元素下類型都是唯一的所以它們會被選擇器匹配到.
nth-child & nth-last-child
這些偽類選擇器最有意思的一點(diǎn)就是可以傳入一個(gè)公式 an+b
, 根據(jù)這個(gè)公式來匹配元素. 這個(gè)公式有很多玩法, 導(dǎo)致有很多人將這個(gè)公式的所有組合以及所匹配的內(nèi)容背下來.
實(shí)際上我們的思考方式被 css 給固化了, 因?yàn)檫@個(gè)東西從數(shù)學(xué)的角度來看非常容易摸清楚規(guī)律, 例如有如下的代碼:
<style> p:nth-child(2n+1){ color:blue; } </style> <body> <p>第一行</p> <p>第二行</p> <p>第三行</p> </body>
思考模式:
- 先收集匹配到的元素, 在這個(gè)例子中就是三個(gè)
<p>
標(biāo)簽 - 從下標(biāo) 0 后數(shù)到 2 表示
<p>
的個(gè)數(shù), 依次帶入公式求值 - 將對應(yīng)下標(biāo)的元素進(jìn)行匹配(元素下標(biāo)從1開始數(shù))
結(jié)果:
公式 | 解釋 |
---|---|
2n | 所有偶數(shù)元素 |
2n+1 | 所有奇數(shù)元素 |
n & n+1 | 所有元素 |
n+2 | 第二個(gè)元素后的元素(包括第二個(gè)元素) |
n+3 | 第三個(gè)元素后的元素(包括第三個(gè)元素) |
0n | 啥都匹配不到 |
3n+4 | 4,7,10,13 .... |
1 | 只匹配第一個(gè)元素 |
-n+2 | 只匹配前兩個(gè)元素 |
nth-child(odd) | 奇數(shù)元素 |
nth-child(even) | 偶數(shù)元素 |
不過不要忘記了 nth-child
匹配的依然是同一組兄弟元素, 不過有趣的是 nth-child
會利用選擇器進(jìn)行過濾, 但是應(yīng)用樣式的時(shí)候卻不把樣式應(yīng)用到匹配的元素上:
上圖中 <div>
中的兩組 <p>
元素被視為兄弟元素進(jìn)行匹配, 但是有趣的是作為第三個(gè) <p>
元素 "第三行" 也被匹配到了, 這說明在應(yīng)用樣式會直接應(yīng)用在一組兄弟元素中而不是被匹配到的 <p>
元素, 不過需要注意的是如果圖片中的 "第三組" 中的 <p>
是 <div>
的話類型不同樣式是不會被應(yīng)用的.
nth-last-child
就是從后向前的版本, 這里就不在詳細(xì)舉例了:
MDN 上還給出了一個(gè)有意思的例子, 可以根據(jù)元素的數(shù)量來控制元素的樣式:
li:nth-last-child(n+3), li:nth-last-child(n+3) ~ li { color: red; }
<h4>A list of four items (styled):</h4> <ol> <li>One</li> <li>Two</li> <li>Three</li> <li>Four</li> </ol> <h4>A list of two items (unstyled):</h4> <ol> <li>One</li> <li>Two</li> </ol>
nth-of-type & nth-last-of-type
nth-of-type
匹配:
- 同一組中相同類型的兄弟元素
- 匹配對應(yīng)公式計(jì)算值的元素
你注意到了嗎 nth-of-type
和 nth-child
是有些區(qū)別的, 計(jì)算完成后樣式的應(yīng)用到了被匹配的元素身上, 而不是兄弟元素上.
nth-last-of-type
是一個(gè)從后向前的版本, 這里不在詳細(xì)介紹:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
- 這篇文章主要介紹了詳解css3中的偽類before和after常見用法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-17
- 這篇文章主要介紹了CSS偽類:empty讓我眼前一亮,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-03
- 這篇文章主要介紹了淺談CSS 偽元素&偽類的妙用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)2020-09-01
- 這篇文章主要介紹了CSS 偽類修改input選中樣式的示例代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-21
css偽類 右下角點(diǎn)擊出現(xiàn) 對號角標(biāo)表示選中的示例代碼
這篇文章主要介紹了css偽類 右下角點(diǎn)擊出現(xiàn) 對號角標(biāo)表示選中,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-22- 這篇文章主要介紹了css選擇器四大類:基本、組合、屬性、偽類的相關(guān)知識,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-14
詳解如何使用CSS3中的結(jié)構(gòu)偽類選擇器和偽元素選擇器
這篇文章主要介紹了詳解如何使用CSS3中的結(jié)構(gòu)偽類選擇器和偽元素選擇器,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面2020-01-06解決移動(dòng)端跳轉(zhuǎn)問題(CSS過渡、target偽類)
這篇文章主要介紹了解決移動(dòng)端跳轉(zhuǎn)問題(CSS過渡、target偽類),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編2019-10-10- 這篇文章主要介紹了CSS新增的:where和:is偽類函數(shù)是什么的相關(guān)知識,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-15