知識目標
- 掌握屬性選擇器的使用
- 掌握關系選擇器的使用
- 掌握結構化偽類選擇器的使用
- 掌握偽元素選擇器的使用
如何減少文檔內class屬性和id屬性的定義,使文檔變得更加簡潔?
可以通過屬性選擇器、關系選擇器、結構化偽類選擇器、偽元素選擇器。
1. 屬性選擇器
1.1 E[attribute]選擇器
E[attribute]選擇器用于選取標簽名稱為E(代指標簽名稱),并且定義了attribute(代指屬性名稱)屬性的標簽。其中,E可以省略,如果省略則表示可以匹配滿足條件的任意標簽。
例1:選取包含id
屬性的<div>
標簽:div[id]
例2:選取包含align
屬性,屬性值為center
的全部標簽:[align=center]
1.2 E[attribute~=value]選擇器
E[attribute~=value]選擇器用于選取標簽名稱為E(代指標簽名稱),并且定義了attribute(代指屬性名稱)屬性,包含某個value(代指屬性值字符)屬性值的標簽。
E[attribute]選擇器和E[attribute~=value]選擇器區別在于前者需要屬性和屬性值完全一致,后者只要標簽包含屬性值即可被選中。
1.3 E[attribute|=value]
E[attribute|=value]選擇器能夠選取帶有value屬性值或以value-開頭的屬性值的標簽,不包括兩個屬性的標簽。
例1: [class|=a] { }
選取屬性值為a或屬性值以a-開頭的標簽。一般用于匹配en-US、zh-CN 等。
1.4 E[attribute^=value]
E[attribute^=value]選擇器能夠選取以value開頭的屬性值的標簽。
例1:選取屬性值以one開頭的標簽 [class ^=one] {}
1.5 E[attribute$=value]
E[attribute$=value]
選擇器用于選擇屬性值后綴為value(代指屬性值字符)字符的標簽。
例1: div[id$=section]
選取包含id屬性,且id屬性值以section字符串結尾的div標簽。
1.6 E[attribute*=value]
E[attribute*=value]選擇器
用于選擇屬性值包含value(代指屬性值字符)字符的標簽。
例1:div[i*=section]
選取包含id屬性,且id屬性值包含“section”字符的<div>
標簽
1.7 總結
選擇器和作用列表如下:
2. 關系選擇器
2.1 子元素選擇器
子元素選擇器主要用來選擇父級標簽的子標簽,由符號“>”連接標簽名稱。
例如:h1>strong
選取<h1>
標簽中的子標簽<strong>
標簽
2.2 兄弟選擇器
兄弟選擇器可以選擇位于同一個父標簽中,指定標簽后面,具有并列關系的子標簽。在CSS3中,兄弟選擇器分為鄰近兄弟選擇器和普通兄弟選擇器兩種。
2.2.1 鄰近兄弟選擇器
使用加號**“+”連接前后兩個選擇器。選擇器中的兩個子標簽從屬同一個父標簽,而且被選取子標簽必須緊跟指定的標簽。強調“緊接”,如A+B,選擇的B必須是A之后的第一個兄弟元素**。
2.2.2 普通兄弟選擇器
使用**“~”**來連接前后兩個選擇器。選擇器中的兩個子標簽從屬同一個父標簽,而且被選取子標簽需要位于指定的標簽后面。如A~B
只要B是A后面出現的兄弟都能被選擇。
3. 結構化偽類選擇器
3.1 :root
:root選擇器
用于匹配文檔根標簽,在HTML中,根標簽指的<html>
標簽。因此使用:root選擇器
定義的樣式,對所有頁面標簽都生效。
3.2 :not
:not選擇器
可以排除設置的標簽或屬性。例如,h3:not(.one)
會選取沒有類名.one的<h3
>標簽。
3.3 :only-child
:only-child選擇器
用于選取父標簽中的唯一子標簽,也就是說,如果某個父標簽僅有一個子標簽,使用:only-child選擇器
可以選擇這個子標簽。例p:only-child
能選中我是獨生子,而不滿足類型的div和多個孩子的標簽不能被選中。
<body><div><p>我是獨生子</p></div><div><div>我是獨生子,是div</div></div><div><p>我是第1個段落</p><p>我是第2個段落</p></div>
</body>
3.4 :first-child
:first-child選擇器
用于選擇父標簽中的第一個子標簽。
3.5 :last-child
:last-child選擇器
用于選取父標簽中的最后一個子標簽。
3.6 :nth-child(n)和nth-last-child(n)
:nth-child(n)
選擇器用于選擇父標簽中的第n個子標簽。例如:選取父標簽中的第2個子標簽::nth-child(2)
。
:nth-last-child(n)
用于選取父標簽中的倒數第n個子標簽。
此時還可以使用關鍵字、公式等進行選擇;
比如:nth-child(even), 選擇的是偶數孩子。
比如:nth-child(3n), 選擇的是3倍數的孩子。
3.7 :first-of-type和:last-of-type
:first-of-type選擇器
用于匹配父標簽中第1個特定類型的子標簽。例如p:first-of-type
,選擇父標簽中的第1個p類型的子標簽。
:last-of-type選擇器
用于匹配父標簽中最后1個特定類型的子標簽。
nth-of-type(n)和nth-child(n)
區別:前面的會把指定元素的例子排序序號再選,后面的會先排序,然后看當前的序號孩子是否滿足是指定元素。
4. 偽元素選擇器
4.1 :empty
:empty選擇器
用來選擇沒有子標簽或內容為空的所有標簽。
4.2 :target
:target選擇器
用于突出顯示當前活動的目標元素。只有用戶單擊頁面中的超鏈接,并且跳轉到:target選擇器
控制的元素后,:target選擇器
所設置的樣式才會起作用。
4.3 :before :after
:before選擇器
/ :after選擇器
用于在被選取標簽的前面/后面插入內容(屬于行內元素,在文檔中找不到的,稱為偽元素)。在使用:before選擇器
/ :after選擇器
時必須配合content屬性來指定要插入的具體內容。
常用場景:1. 鼠標放上去出現的遮罩、圖層 2.
5. 實踐
我會提供代碼但會將樣式刪除,接下來的案例題麻煩大家使用以上述學的知識來補充選擇器及樣式!!!可以在評論區上傳自己的代碼和樣例截圖哦!!!
提供的樣例代碼:
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>CSS3 Selectors Example</title><!-- 整體頁面樣式需求:1. 字體使用 Arial 或無襯線字體 2. 行高為 1.6 3. 頁面邊距為 20px-->
</head><body><!-- h1 樣式需求:1. 顏色為 #333 2. 字體大小為 2em 3. 文本居中對齊 4. 文本陰影為 2px 2px 4px rgba(0, 0, 0, 0.1) --><h1>CSS3 Selectors Example</h1><!-- h2 樣式需求:1. 顏色為 #5552. 字體大小為 1.6em3. 底部有 1px 實線的 #ccc 顏色邊框4. 底部內邊距為 5px --><h2>屬性選擇器示例</h2><!-- a標簽樣式需求,可采用E[att="value"]的方式進行選擇:1. 顏色為橙色2. 去除下劃線3. 字體加粗 --><p>訪問 <a href="https://www.example.com" target="_blank">安全網站</a> 獲取更多信息。</p><!-- img[src^="images/"] 樣式需求:1. 邊框為 2px 實線的 #ccc 顏色2. 邊框圓角為 5px3. 陰影為 0 0 5px rgba(0, 0, 0, 0.3)--><p><img src="images/sample.jpg" alt="Sample Image"></p><!-- highlight樣式需求 采用*= 的方式:1. 背景顏色為黃色2. 字體大小為 1.1em--><p class="highlight">這是一個高亮顯示的段落。</p><!-- 樣式需求: 采用$=的方式1. 顏色為藍色2. 字體為斜體--><p>下載 <a href="document.docx">文檔</a> 了解詳情。</p><!-- important樣式需求: 采用~=選擇的方式1. 顏色為紅色2. 字體加粗3. 有下劃線--><p>這里有個 <span class="important">重要</span> 的信息。</p><!-- li[data-lang|="en"] 樣式需求:1. 背景顏色為淺藍色2. 字體大小為 0.9em--><!-- ul 樣式需求:1. 列表樣式類型為圓形2. 左內邊距為 20px--><ul><li data-lang="en-US">英文列表項1</li><li data-lang="fr-FR">法文列表項2</li><li data-lang="en-GB">英文列表項3</li></ul><!-- h3 樣式需求:1. 顏色為 #7772. 字體大小為 1.3em--><h3>兄弟選擇器示例</h3><!-- h3 + p 樣式需求:1. 字體為斜體2. 顏色為 #7773. 字體大小為 0.95em--><p>這是緊跟在h3后面的段落,使用鄰兄弟選擇器設置樣式。</p><!-- h3 ~ ol 樣式需求:1. 背景顏色為 #f9f9f92. 邊框為 1px 實線的 #ddd 顏色3. 內邊距為 10px--><!-- ul li:first-child 樣式需求:1. 字體加粗2. 字體大小為 1.1em3. 顏色為 #333--><!-- ul li:last-child 樣式需求:1. 有下劃線2. 字體為斜體--><!-- ul li:nth-child(3n) 樣式需求:背景顏色為 #eee--><!-- ol li:nth-child(even) 樣式需求:1. 顏色為紫色2. 字體大小為 1.05em--><!-- ol li:nth-child(odd) 樣式需求:顏色為 #555--><!-- ol 樣式需求:列表樣式類型為大寫羅馬數字左內邊距為 25px--><!-- p 樣式需求:顏色為 #666--><ol><li>有序列表項1</li><li>有序列表項2</li><li>有序列表項3</li><li>有序列表項4</li><li>有序列表項5</li></ol><!-- h2 樣式需求:同上面的 h2 樣式需求--><h2>表格示例</h2><!-- table 樣式需求:1. 邊框合并,無邊框間距2. 寬度為 100%--><!-- th 樣式需求:1. 背景顏色為 #f0f0f02. 字體加粗3. 文本居中對齊4. 內邊距為 8px--><!-- td 樣式需求:1. 邊框為 1px 實線的 #ccc 顏色2. 內邊距為 8px--><!-- 奇數孩子樣式需求:可使用:nth-child(even)的方式 使用背景顏色為 #f9f9f9--><table><thead><tr><th>姓名</th><th>年齡</th><th>職業</th></tr></thead><tbody><tr><td>張三</td><td>25</td><td>程序員</td></tr><tr><td>李四</td><td>30</td><td>設計師</td></tr><tr><td>王五</td><td>22</td><td>學生</td></tr></tbody></table><!-- a.info-link 樣式需求:1. 顏色為 green2. 文本有下劃線--><p>更多信息請訪問 <a href="#" class="info-link">這里</a>。</p><!-- span.secondary 樣式需求:1. 顏色為 #9992. 字體大小為 0.9em--><p><span class="secondary">這是一段次要信息</span>,需要特殊樣式。</p>
</body></html>
需實現的樣式如圖所示: