溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

CSS3中nth-child與nth-of-type的區(qū)別是什么

發(fā)布時間:2023-01-04 09:19:17 來源:億速云 閱讀:111 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“CSS3中nth-child與nth-of-type的區(qū)別是什么”的相關(guān)知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“CSS3中nth-child與nth-of-type的區(qū)別是什么”文章能幫助大家解決問題。

CSS3中nth-child與nth-of-type的區(qū)別其實很簡單::nth-of-type為什么要叫:nth-of-type?因為它是以"type"來區(qū)分的。也就是說:ele:nth-of-type(n)是指父元素下第n個ele元素, 而ele:nth-child(n)是指父元素下第n個元素且這個元素為ele,若不是,則選擇失敗。

文字未免聽起來比較晦澀,便于理解,這里附上一個小例子:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>demo</title>
</head>
<style>
.demo li:nth-child(2){
color: #ff0000;
}
.demo li:nth-of-type(2){
color: #00ff00;
}
</style>
<body>
<div>
<ul class="demo">
<p>zero</p>
<li>one</li>
<li>two</li>
</ul>
</div>
</body>
</html>

結(jié)果如下:

CSS3中nth-child與nth-of-type的區(qū)別是什么

上面這個例子,.demo li:nth-child(2)選擇的是<li>one</li>節(jié)點,而.demo li:nth-of-type(2)則選擇的是<li>two</li>節(jié)點。

但是如果在nth-child和 nth-of-type前不指定標簽呢?

.demo :nth-child(2){
color: #ff0000;
}
.demo :nth-of-type(2){
color: #00ff00;
}

這樣又會是什么結(jié)果呢,看下html結(jié)構(gòu):

<ul class="demo">
<p>first p</p>
<li>first li</li>
<li>second li</li>
<p>second p</p>
</ul>

結(jié)果:

CSS3中nth-child與nth-of-type的區(qū)別是什么

如上可見,在他們之前不指定標簽類型,:nth-child(2) 選中依舊是第二個元素,無論它是什么標簽。而 :nth-type-of(2) 選中了兩個元素,分別是父級.demo中的第二個p標簽和第二個li標簽,由此可見,不指定標簽類型時,:nth-type-of(2)會選中所有類型標簽的第二個。

我們已經(jīng)了解了nth-child和 nth-of-type的基本使用與區(qū)別,那么更進一步nth-of-type(n)與nth-child(n)中的n是什么呢?

nth-of-type(n)與nth-child(n)中的n可以是數(shù)字、關(guān)鍵詞或公式。 數(shù)字:也就是上面例子的使用,就不做贅述。 關(guān)鍵詞:Odd 、even

Odd 和 even 是可用于匹配下標是奇數(shù)或偶數(shù)的子元素的關(guān)鍵詞

注意:第一個子元素的下標是 1

在這里,我們?yōu)槠鏀?shù)和偶數(shù) p 元素指定兩種不同的背景色:

p:nth-of-type(odd)
{
background:#ff0000;
}
p:nth-of-type(even)
{
background:#0000ff;
}

公式:或者說是算術(shù)表達式

使用公式 (an + b)。描述:表示周期的長度,n 是計數(shù)器(從 0 開始),b 是偏移值。

在這里,我們指定了下標是 3 的倍數(shù)的所有 p 元素的背景色:

p:nth-of-type(3n+0)
{
background:#ff0000;
}

若是 :nth-of-type(4n+2) 就是選擇下標是4的倍數(shù)加上2的所有元素

關(guān)于“CSS3中nth-child與nth-of-type的區(qū)別是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識,可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI