CSS3选择器:nth-child和:nth-of-type之间的差异
生活随笔
收集整理的這篇文章主要介紹了
CSS3选择器:nth-child和:nth-of-type之间的差异
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
1. 深呼吸,直接內(nèi)容
:nth-child和:nth-of-type都是CSS3中的偽類選擇器,其作用近似卻又不完全一樣,對(duì)于不熟悉的人對(duì)其可能不是很區(qū)分,本文就將介紹兩者的不同,以便于大家正確靈活使用這兩類選擇器
先看一個(gè)簡單的實(shí)例,首先是HTML部分:
上面這個(gè)例子中,這兩個(gè)選擇器所實(shí)現(xiàn)的效果是一致的,第二個(gè)p標(biāo)簽的文字變成了紅色,如下截圖(截自IE9)
盡管上面兩個(gè)demo的最后效果一致,但是兩個(gè)選擇器之間存在差異是必然的
對(duì)于:nth-child選擇器,在簡單白話文中,意味著選擇一個(gè)元素
1. 這個(gè)元素是個(gè)段落元素
2. 這個(gè)元素是父標(biāo)簽的第二個(gè)孩子元素
對(duì)于:nth-of-type選擇器,意味著選擇一個(gè)元素
1. 選擇父標(biāo)簽中特定標(biāo)簽的第二個(gè)段落子元素
:nth-of-type選擇器,恩……怎么講呢?限制條件少點(diǎn)~~
我們把上面的實(shí)例稍作修改,就可以看到這兩個(gè)選擇器之間的差異表現(xiàn)了,如下HTML代碼
這時(shí)候兩個(gè)選擇器所渲染的結(jié)果就不一樣了
p:nth-child(2)悲劇了,其渲染的結(jié)果不是第二個(gè)p標(biāo)簽文字變紅,而是第一個(gè)p標(biāo)簽,也就是父標(biāo)簽的第二個(gè)子元素。如下效果截圖
p:nth-of-type(2)的表現(xiàn)顯得很堅(jiān)挺,其把希望渲染的第二個(gè)p標(biāo)簽染紅了,如下截圖
對(duì)照上面兩個(gè)選擇器的語義,此處的效果表現(xiàn)差異不難理解
對(duì)于p:nth-child(2)表示這個(gè)元素要是p標(biāo)簽,且是第二個(gè)子元素,是兩個(gè)必須滿足的條件。于是,就是第一個(gè)p標(biāo)簽顏色為紅色(正好符合:p標(biāo)簽,第二個(gè)子元素)。如果在div標(biāo)簽后面再插入個(gè)span標(biāo)簽,如下
那么p:nth-child(2)將不會(huì)選擇任何元素
而p:nth-of-type(2)表示父標(biāo)簽下的第二個(gè)p元素,顯然,無論在div標(biāo)簽后面再插入個(gè)span標(biāo)簽,還是h1標(biāo)簽,都是第二個(gè)p標(biāo)簽中的文字變紅
這兩者的差異用一個(gè)跟切合實(shí)際的情況比喻就是計(jì)劃生育查人口:前者是如果是第二胎,且是女孩,罰款!后者是管他第幾胎,第二個(gè)出身的女孩,罰款!
2. 二次深呼吸,個(gè)人體會(huì)
老實(shí)講,對(duì)于:nth-child和:nth-of-type這兩個(gè)屬性自己用的并不多,對(duì)這兩個(gè)屬性的認(rèn)識(shí)就像是一團(tuán)漿糊。印象在使用:last-child這個(gè)類似選擇器的時(shí)候,出現(xiàn)了沒有效果的情況,現(xiàn)在想想,就是因?yàn)閷?duì)選擇器的理解不夠透徹,所以使用的時(shí)候出問題的
今天對(duì)這兩個(gè)選擇器好好地過了遍之后,個(gè)人覺得:nth-of-type更彪悍些,不容易出問題,盡管:nth-child貌似更常見些。所以以后要選擇某某元素下的第幾個(gè)什么標(biāo)簽,建議使用:nth-of-type,因?yàn)轫撁嬖夭迦肫渌麡?biāo)簽啊什么的是比較常見的,如果使用:nth-child,選擇器可能就是嗝屁
不過嘛,世事無絕對(duì),最靠譜的就是對(duì)這兩個(gè)選擇器徹徹底底地了解,具體情況具體使用
另外一個(gè)小小的建議,為了避免出現(xiàn)“尼瑪我的:nth-child變成打醬油的不頂鳥用啦!”這樣的疑問,最好使用父標(biāo)簽層級(jí)限制,而不是當(dāng)前標(biāo)簽類型限制。如下示例
當(dāng)然,還是那句話,要看實(shí)際情況如何,沒有一勞永逸,一方通行的代碼
總結(jié)
以上是生活随笔為你收集整理的CSS3选择器:nth-child和:nth-of-type之间的差异的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 教你十分钟构建好 SpringBoot
- 下一篇: CSS之media Query