關(guān)于偽類(lèi)選擇器first-child和first-of-type

逼自己說(shuō)幾句


這篇文章是從我上一個(gè)簡(jiǎn)書(shū)賬號(hào)里粘貼過(guò)來(lái)的烛芬,當(dāng)時(shí)第一次學(xué)CSS選擇器,記得很清楚,對(duì)于first-childfitst-of-type確實(shí)比較懵杉允,于是整理了他們倆的區(qū)別。

記得當(dāng)時(shí)總結(jié)出來(lái)的時(shí)候有一種茅塞頓開(kāi)的感覺(jué)席里。

所以還是說(shuō)叔磷,自學(xué),還是需要不斷去寫(xiě)技術(shù)性博客奖磁,真的很有用改基。

兩者的定義


  • :first-child 選擇器用于選取屬于其父元素的首個(gè)子元素的指定選擇器。
  • :first-of-type 選擇器匹配屬于其父元素的特定類(lèi)型的首個(gè)子元素的每個(gè)元素咖为。

定義的解析


  • :first-child 當(dāng)出現(xiàn) p:first-child 時(shí)秕狰,其所匹配的元素必須符合以下兩點(diǎn):1.必須為p標(biāo)簽;2.必須為某個(gè)父元素的第一個(gè)子元素

  • :first-of-type 當(dāng)出現(xiàn) p:first-of-type 時(shí)躁染,其所匹配的元素為所有子元素中的第一個(gè)p標(biāo)簽(不論該p標(biāo)簽是否為第一個(gè)子元素)

定義的深度解析


一個(gè)父元素會(huì)包括一個(gè)或多個(gè)子元素

<div class="parent">
  <div>Child</div>
  <div>Child</div>
  <div>Child</div>
  <div>Child</div>
</div>

在這些子元素中鸣哀,只有一個(gè)是排名第一的,這就是:first-child

<div class="parent">
  <div>Child</div>/*first-child*/
  <div>Child</div>
  <div>Child</div>
  <div>Child</div>
</div>

first-of-typefirst-child 的區(qū)別在于它匹配的是該元素類(lèi)型的第一個(gè)子元素吞彤,可能這個(gè)元素并不是該父元素的第一個(gè)子元素

如果 XXX:first-child 存在我衬,任何的 XXX:first-child 肯定是 XXX:first-of-type

div class="parent">
  <div>Child</div> <!-- div:first-child, div:first-of-type -->
  <div>Child</div>
  <div>Child</div>
  <div>Child</div>
</div>

如果把上面的代碼的子元素的第一個(gè) div 給換掉,比如換成 h1 饰恕,那么這個(gè) h1 仍然是其父元素的第一個(gè)子元素挠羔,但是已經(jīng)不是第一個(gè) div 了。第二行的 div 是其父元素的第二個(gè)子元素埋嵌,而且是第一個(gè) div 破加。具體的注釋請(qǐng)看如下的代碼:

<div class="parent">
  <h1>Child</h1>   <!-- h1:first-child, h1:first-of-type -->
  <div>Child</div> <!-- div:nth-child(2), div:first-of-type -->
  <div>Child</div>
  <div>Child</div>
</div>

同時(shí), first-child 在任何情況下都只能匹配到一個(gè)元素莉恼,而 first-of-type 在一些情況下能匹配到不止一個(gè)元素拌喉,如下代碼:

<div class="parent">
  <h1>Child</h1>   <!-- .parent > :first-of-type -->
  <div>Child</div> <!-- .parent > :first-of-type -->
  <div>Child</div>
  <div>Child</div>
</div>

實(shí)例運(yùn)用


代碼地址

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>first-child對(duì)比f(wàn)irst-of-type</title>
<style>
.parent :first-child{
  color: red;
}
.parent :first-of-type{
  background: yellow;
}
.parent div:first-child{
  font-size: 50px;
}
.parent div:nth-child(3){
  text-decoration: line-through;
}
.parent div:first-of-type{
  border: 1px green solid;
}
.parent p:first-child{
  text-decoration: underline;
}
</style>
</head>
<body>
<div class="parent">
  <p>child1</p>
    <div>child2</div>
    <div>child3</div>
    <div>child4</div>
  </div>
</body>
</html>

運(yùn)行結(jié)果:

詳細(xì)分析以上代碼得出:

.parent :first-child{
  color: red;
}

以上代碼匹配parent這個(gè)父元素的首個(gè)子元素速那,所以child1變成了紅色

.parent :first-of-type{
  background: yellow;
}

以上代碼匹配parent這個(gè)父元素的所有標(biāo)簽的首個(gè)子元素,其中parent的第一個(gè)子元素是p尿背,同時(shí)也是第一個(gè)p端仰,parent的第二個(gè)子元素是div,同時(shí)也是第一個(gè)div田藐,所以child1和child2的背景顏色變成了黃色

.parent div:first-child{
  font-size: 50px;
}

以上代碼匹配parent這個(gè)父元素的首個(gè)子元素荔烧,并且這個(gè)首個(gè)子元素必須為div,然而parent這個(gè)父元素的首個(gè)子元素為p汽久,所以沒(méi)有任何的元素被匹配上

.parent div:nth-child(3){
  text-decoration: line-through;
}

以上代碼匹配parent這個(gè)父元素的第三個(gè)子元素鹤竭,并且這個(gè)子元素為div,所以child3有刪除線(xiàn)的效果

.parent div:first-of-type{
  border: 1px green solid;
}

以上代碼匹配parent這個(gè)父元素的第一個(gè)div子元素景醇,所以child2有實(shí)現(xiàn)框的效果

.parent p:first-child{
  text-decoration: underline;
}

以上代碼匹配parent這個(gè)父元素的第一個(gè)子元素臀稚,并且這個(gè)子元素為p,所以child1有下劃線(xiàn)的效果


參考文章:

(完)

文檔信息

  • 自由轉(zhuǎn)載-非商用-非衍生-保持署名
  • 發(fā)表日期:2016年9月8日
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末三痰,一起剝皮案震驚了整個(gè)濱河市吧寺,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌散劫,老刑警劉巖稚机,帶你破解...
    沈念sama閱讀 206,214評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異获搏,居然都是意外死亡赖条,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)常熙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)纬乍,“玉大人,你說(shuō)我怎么就攤上這事症概±俣睿” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,543評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵彼城,是天一觀的道長(zhǎng)诅蝶。 經(jīng)常有香客問(wèn)我,道長(zhǎng)募壕,這世上最難降的妖魔是什么调炬? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,221評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮舱馅,結(jié)果婚禮上缰泡,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好棘钞,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布缠借。 她就那樣靜靜地躺著,像睡著了一般宜猜。 火紅的嫁衣襯著肌膚如雪泼返。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,007評(píng)論 1 284
  • 那天姨拥,我揣著相機(jī)與錄音绅喉,去河邊找鬼。 笑死叫乌,一個(gè)胖子當(dāng)著我的面吹牛柴罐,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播憨奸,決...
    沈念sama閱讀 38,313評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼革屠,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了膀藐?” 一聲冷哼從身側(cè)響起屠阻,我...
    開(kāi)封第一講書(shū)人閱讀 36,956評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎额各,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體吧恃,經(jīng)...
    沈念sama閱讀 43,441評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡虾啦,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了痕寓。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片傲醉。...
    茶點(diǎn)故事閱讀 38,018評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖呻率,靈堂內(nèi)的尸體忽然破棺而出硬毕,到底是詐尸還是另有隱情,我是刑警寧澤礼仗,帶...
    沈念sama閱讀 33,685評(píng)論 4 322
  • 正文 年R本政府宣布吐咳,位于F島的核電站,受9級(jí)特大地震影響元践,放射性物質(zhì)發(fā)生泄漏韭脊。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評(píng)論 3 307
  • 文/蒙蒙 一单旁、第九天 我趴在偏房一處隱蔽的房頂上張望沪羔。 院中可真熱鬧,春花似錦象浑、人聲如沸蔫饰。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,240評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)篓吁。三九已至趋距,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間越除,已是汗流浹背节腐。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,464評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留摘盆,地道東北人翼雀。 一個(gè)月前我還...
    沈念sama閱讀 45,467評(píng)論 2 352
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像孩擂,于是被迫代替她去往敵國(guó)和親狼渊。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容