鍍金池/ 問(wèn)答/C  HTML/ 當(dāng)<p>遇上:first-child出現(xiàn)的問(wèn)題

當(dāng)<p>遇上:first-child出現(xiàn)的問(wèn)題

多層<p>相互嵌套,然后用p:first-child選擇器,無(wú)法正確選擇,代碼:

<body>
    <p>111
        <p>222
            <p>333</p>
        </p>
    </p>
</body>

此時(shí)用 p:first-child{color:red;} ,只有111變?yōu)榧t色,為什么不是所有數(shù)字變紅?

我嘗試把所有<p>換為<span>或者<div>或者<code>,再換用相應(yīng)的選擇器,均能實(shí)現(xiàn)全部數(shù)字變紅。

我所理解的p:first-child,可以選擇到的標(biāo)簽必須滿足2個(gè)條件:

  1. 元素名為p(廢話)
  2. 該p是作為第一個(gè)子元素(無(wú)關(guān)乎父元素是哪個(gè))

是我對(duì) :first-child 這個(gè)偽類理解錯(cuò)了,還是<p>特有的原因,導(dǎo)致全部數(shù)字不能變紅?

回答
編輯回答
朽鹿

p 標(biāo)簽是不允許嵌入 p 標(biāo)簽內(nèi).

所以你的嵌入層級(jí)的 p 在瀏覽器看來(lái)是這樣的.

<p> // 第一個(gè) p
    <p>  // 自動(dòng)為第一個(gè) p 補(bǔ)全關(guān)閉標(biāo)簽, 開(kāi)始第二個(gè) p
        <p> // 自動(dòng)為第二個(gè) p 補(bǔ)全關(guān)閉標(biāo)簽, 開(kāi)始第三個(gè) p
        </p> // 第三個(gè) p 結(jié)束
    </p> // 第四個(gè) p 開(kāi)始, 為其補(bǔ)充開(kāi)始標(biāo)簽
</p> // 第五個(gè) p 開(kāi)始, 為其補(bǔ)充開(kāi)始標(biāo)簽

結(jié)果就是:

<p></p> // 只有這個(gè)滿足 p:first-child
<p></p>
<p></p>
<p></p>
<p></p>
2018年2月14日 18:46
編輯回答
孤毒

題主問(wèn)了一個(gè)有意思的問(wèn)題。

稍微試驗(yàn)了一下,很容易從DOM結(jié)構(gòu)得到:

<p><p><p></p></p></p>這樣的結(jié)構(gòu)會(huì)被瀏覽器解析為:

<!--生成了5個(gè)p-->
<p></p>
<p></p>
<p></p>
<p></p>
<p></p>

證明p中遇到p標(biāo)簽會(huì)自動(dòng)閉合。

在p中不能包含塊級(jí)元素,比如<p><div></div></p>

同樣會(huì)被解析成:

<p></p>
<div></div>
<p></p>

更深入一步,可以看看知乎上的問(wèn)答,一個(gè)HTML規(guī)范:a 標(biāo)簽為什么能夠包含塊級(jí)元素?

按新的 HTML 規(guī)范,已經(jīng)不按 inline 和 block 來(lái)區(qū)分元素類型了。在規(guī)范中每個(gè)元素會(huì)規(guī)定如下兩項(xiàng):Categories、 Content Model
Categories 是改元素本身的分類,content model 規(guī)定了合法的元素的內(nèi)容(子元素、文本等)類型。
2018年2月1日 01:20