400-650-7353
您所在的位置:首頁(yè) > IT干貨資料 > web前端 > 【W(wǎng)eb前端基礎(chǔ)知識(shí)】:nth-child()和:nth-of-type()的區(qū)別

【W(wǎng)eb前端基礎(chǔ)知識(shí)】:nth-child()和:nth-of-type()的區(qū)別

  • 發(fā)布: Web前端培訓(xùn)
  • 來(lái)源:Web前端干貨資料
  • 2020-09-11 14:59:08
  • 閱讀()
  • 分享
  • 手機(jī)端入口

:nth-child和:nth-of-type都是css3的結(jié)構(gòu)偽類(lèi)選擇器,和他們相關(guān)的還有一堆其他的結(jié)構(gòu)偽類(lèi)選擇器,如果搞懂了這兩個(gè)選擇器的話,相應(yīng)的也能搞懂和他們相關(guān)的其他結(jié)構(gòu)偽類(lèi)選擇器啦。

這兩個(gè)選擇器,可不像我們看起來(lái)的那么簡(jiǎn)單,他們的作用相近,卻又不完全一樣。

定義

我們先來(lái)看下這兩個(gè)選擇器的定義:

:nth-child(n) 選擇器匹配父元素中的第 n 個(gè)子元素,元素類(lèi)型沒(méi)有限制。

:nth-of-type(n)選擇器匹配同類(lèi)型中的第n個(gè)同級(jí)兄弟元素。

n可以是一個(gè)數(shù)字,一個(gè)關(guān)鍵字,或者一個(gè)公式。

寫(xiě)個(gè)例子看下:

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4.     <meta charset="UTF-8"> 
  5.     <title>:nth-child()和:nth-of-type()的區(qū)別</title> 
  6.     <style> 
  7.         .box p:nth-child(2){ 
  8.             color:#fff; 
  9.             background: orange; 
  10.         } 
  11.     </style> 
  12. </head> 
  13. <body> 
  14.     <div class="box"> 
  15.         <h2>我是h2標(biāo)簽</h2> 
  16.         <p>我是.box里的第二個(gè)子元素,我是第一個(gè)p標(biāo)簽</p> 
  17.         <p>我是.box里的第三個(gè)子元素,我是第二個(gè)p標(biāo)簽</p> 
  18.     </div> 
  19. </body> 
  20. </html> 

效果如下:

 

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4.     <meta charset="UTF-8"> 
  5.     <title>:nth-child()和:nth-of-type()的區(qū)別</title> 
  6.     <style> 
  7.         .box p:nth-of-type(2){ 
  8.             color:#fff; 
  9.             background: orange; 
  10.         } 
  11.     </style> 
  12. </head> 
  13. <body> 
  14.     <div class="box"> 
  15.         <h2>我是h2標(biāo)簽</h2> 
  16.         <p>我是.box里的第二個(gè)子元素,我是第一個(gè)p標(biāo)簽</p> 
  17.         <p>我是.box里的第三個(gè)子元素,我是第二個(gè)p標(biāo)簽</p> 
  18.     </div> 
  19. </body> 
  20. </html> 

效果如下:

一個(gè)是.box p:nth-child(2),一個(gè)是.box p:nth-of-type(2),括號(hào)里面都2,但是效果卻不同。那么到底這兩個(gè)選擇器是什么意思呢?

分析:

我們?cè)賮?lái)看下結(jié)構(gòu):

.box的子元素有三個(gè),第一個(gè)是h2標(biāo)簽,第二個(gè)和第三個(gè)是p標(biāo)簽。

  1. <div class="box"> 
  2. <h2>我是h2標(biāo)簽</h2> 
  3.    <p>我是.box里的第二個(gè)子元素,我是第一個(gè)p標(biāo)簽</p> 
  4.    <p>我是.box里的第三個(gè)子元素,我是第二個(gè)p標(biāo)簽</p> 
  5. </div> 

.box p:nth-child(2)

.box p:nth-child(2)的效果是選擇出了第一個(gè)p標(biāo)簽,也就是.box里的第二個(gè)子元素。

翻譯下:

1.確定了選擇的是.box元素里面的p元素。

2.選擇的是.box的子元素里面àp元素à的父元素里面的à第二個(gè)子元素。

3.我們來(lái)分析下第二點(diǎn)到底是什么意思:”.box的子元素里面àp元素”指的是這兩個(gè)元素:

4.“ p元素à的父元素”指的就是.box這個(gè)元素:

文章“【W(wǎng)eb前端基礎(chǔ)知識(shí)】:nth-child()和:nth-of-type()的區(qū)別”已幫助

>>本文地址:http://nfbqydst.cn/zhuanye/2020/55049.html

THE END  

聲明:本站稿件版權(quán)均屬中公教育優(yōu)就業(yè)所有,未經(jīng)許可不得擅自轉(zhuǎn)載。

1 您的年齡

2 您的學(xué)歷

3 您更想做哪個(gè)方向的工作?

獲取測(cè)試結(jié)果
  • 大前端大前端
  • 大數(shù)據(jù)大數(shù)據(jù)
  • 互聯(lián)網(wǎng)營(yíng)銷(xiāo)互聯(lián)網(wǎng)營(yíng)銷(xiāo)
  • JavaJava
  • Linux云計(jì)算Linux
  • Python+人工智能Python
  • 嵌入式物聯(lián)網(wǎng)嵌入式
  • 全域電商運(yùn)營(yíng)全域電商運(yùn)營(yíng)
  • 軟件測(cè)試軟件測(cè)試
  • 室內(nèi)設(shè)計(jì)室內(nèi)設(shè)計(jì)
  • 平面設(shè)計(jì)平面設(shè)計(jì)
  • 電商設(shè)計(jì)電商設(shè)計(jì)
  • 網(wǎng)頁(yè)設(shè)計(jì)網(wǎng)頁(yè)設(shè)計(jì)
  • 全鏈路UI/UE設(shè)計(jì)UI設(shè)計(jì)
  • VR/AR游戲開(kāi)發(fā)VR/AR
  • 網(wǎng)絡(luò)安全網(wǎng)絡(luò)安全
  • 新媒體與短視頻運(yùn)營(yíng)新媒體
  • 直播帶貨直播帶貨
  • 智能機(jī)器人軟件開(kāi)發(fā)智能機(jī)器人
 

快速通道fast track

近期開(kāi)班時(shí)間TIME