CSS 之原來你是這樣子的: first-child

lyning發表於2019-02-19
CSS 之原來你是這樣子的: first-child

前言

寫這篇文章的目的,一方面是糾正自己一直以來對這個偽類的誤解(請看下面的程式碼)和更好的理解瀏覽器對:first-child解析和渲染機制,另一方面是希望通過這篇文章,能夠讓更多的新人深刻理解這個知識點。
注:first-child是CSS2的一個偽類(對於想知道偽元素和偽類的具體定義,請自行Google 或 W3C)。

程式碼示例

這個特定偽類很容易遭到誤解,所以有必要舉例來說明,廢話少說,直接上程式碼:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style type="text/css">
        p:first-child { color: red; }
        li:first-child { color: blue; }
    </style>
</head>
<body>
<div>
    <ul>
        <li>Vue 2</li>
        <li>Angular <strong>2</strong></li>
        <li>React</li>
    </ul>
    <p>Hello Everyone</p>
    <p><em>我</em> 是來搞事的.</p>
</div>
<p><b>註釋:</b>必須宣告 DOCTYPE,這樣 :first-child 才能在 IE 中生效。</p>
</body>
</html>複製程式碼

主要看兩個部分,一是樣式部分,二是HTML主體內容,現在只需要在自己的腦海裡想象出瀏覽器渲染出來的效果,對於這個效果,我將一一腦補出來給大家.
A:我YY出來了,吶

CSS 之原來你是這樣子的: first-child
a

B:可能是這樣

CSS 之原來你是這樣子的: first-child
B

C:應該是這樣吧

CSS 之原來你是這樣子的: first-child
C

D:你們都錯了

CSS 之原來你是這樣子的: first-child
d

CSS 之原來你是這樣子的: first-child

提示:最常見的錯誤是認為 p:first-child 之類的選擇器會選擇 p 元素的第一個子元素。

知識點整理

結果是什麼不重要,先來看看W3C CSS2.1對偽類:first-child的說明和注意事項:

The :first-child pseudo-class matches an element that is the first child element of some other element.

翻譯過來大致是(英文渣渣):”:first-child這個偽類會匹配其它元素中第一個子元素”,也就是說,是相對於其父元素的第一個子元素。

Note that since anonymous boxes are not part of the document tree, they are not counted when calculating the first child.

大致意思是:”匿名元素(比如<p>Hello <b>World</b></p>中的Hello)將不會包含在dom tree裡面,使用:first-child偽類時是不會把匿名元素當成一個元素計算進去”;也就是說,除了匿名元素,其它的任何元素都可以作為父元素,包括<body>、<ul>、<li>等等。

參考CSS2.1標準對於偽類:first-child的說明

我相信細心的人差不多都已經get到點了,第一個知識要點是 相對於父元素的第一個子元素 第二個是 不會計算匿名元素 (雖然我不知道稱為匿名元素準不準確,如果說錯的請輕拍並告訴正確的中文翻譯)

程式碼分析

搞清楚上面提到的知識點之後,我們才能夠有信心的做出專業判斷,現在分析一下之前那段程式碼。
CSS:

p:first-child { color: red; }
li:first-child { color: blue; }複製程式碼

HTML:

<body>
    <div>
        <ul>
            <li>Vue 2</li>
            <li>Angular <strong>2</strong></li>
            <li>React</li>
        </ul>
        <p>Hello Everyone</p>
        <p><em>我</em> 是來搞事的.</p>
    </div>
    <p><b>註釋:</b>必須宣告 DOCTYPE,這樣 :first-child 才能在 IE 中生效。</p>
</body>複製程式碼

CSS分析:
p:first-child { color: red; }是作為某元素(不包含匿名元素)的第一子元素的所有p元素的字型顏色都設定為紅色;
li:first-child { color: blue; }同理;
HTML分析:
<div><body>的第一個子元素,最下面的<p>元素是<body>的:last-child;
<ul>作為<div>第一個子元素,下面兩個<p>很明顯不作為<ul>第一子元素;
<li>Vue2</li>是ul元素的第一個子元素;
以此類推,<em>作為<p>的第一子元素,<b>作為<p>的第一子元素,最終呈現在瀏覽器的效果為…

總結

:first-child和:last-child偽類在WEB開發中使用得非常頻繁,比如使用:last-child清除浮動,使用CSS對:first-child選擇的第一個子元素進行特殊處理;兩者知一曉二,所以對於深刻理解它們是非常有必要。


本文對你有幫助?歡迎掃碼加入前端學習小組微信群:

CSS 之原來你是這樣子的: first-child

相關文章