nth-child和nth-of-type是css的两个伪选择符。应用中,这二者经常容易混淆。这里把它们拿出来仔细作个对比,看看这二者是怎么查找元素的。css
nth-child(n) —— 寻找第n个子元素
nth-of-type(n) —— 寻找同一类型元素里的第n个元素html
看这个定义也许还不是很清楚他们的区别,咱们一点点来区分。spa
- p:nth-child(2) 与 p:nth-pf-type(2)
HTML代码以下code
<div> <div style="float:left;width:200px;"> <p>pgh1</p> <p>pgh2</p> <p>pgh3</p> <p>pgh4</p> </div> <div style="float:left;width:200px;"> <h5>div1</h5> <h5>div2</h5> <h5>div3</h5> <h5>div4</h5> </div>
分别应用两个样式, 都是找第二个元素htm
p:nth-child(2) { color: red; font-weight:bold; } h5:nth-of-type(2) { color: blue; font-weight:bold; }
结果:二者都应用成功。ip
如今咱们对HTML代码作点改动,让他们出现一些不一样。咱们将第一个p元素和第一个h5元素改成label,代码以下:it
<div> <div style="float:left;width:200px;"> <label>pgh1</label> <p>pgh2</p> <p>pgh3</p> <p>pgh4</p> </div> <div style="float:left;width:200px;"> <label>div1</label> <h5>div2</h5> <h5>div3</h5> <h5>div4</h5> </div>
样式不变,这时再来看效果,发现nth-of-type(2)结果变了,这时高亮的是div3。到这里也算符合咱们的逻辑。h5:nth-of-type(2)要找的是第二个h5类型的元素,也就是div3。class
继续改动HTML代码。咱们恢复第一个p元素和第一个h5元素,将第二个p元素和第二个h5元素改成label,样式仍保持不变,结果会怎样呢?
HTML以下:cli
<div> <div style="float:left;width:200px;"> <p>pgh1</p> <label>pgh2</label> <p>pgh3</p> <p>pgh4</p> </div> <div style="float:left;width:200px;"> <h5>div1</h5> <label>div2</label> <h5>div3</h5> <h5>div4</h5> </div>
CSS 不变:float
p:nth-child(2) { color: red; font-weight:bold; } h5:nth-of-type(2) { color: blue; font-weight:bold; }
结果:nth-child没有效果,nth-of-type高亮的是div3。
为何会这样呢?
因此,nth-child和nth-of-type的不一样之处就是查找元素的方式不一样。前者是查找兄弟元素中某个绝对位置的元素,后者是查找同类型元素中某个绝对位置的元素。相同之处是,二者都是找到元素以后再与前面的选择符进行匹配,这里的匹配方式是同样的。
稍微往下延伸,清楚了查找方式,那么无论前面的选择符怎么变,最后都是先查找到元素再与前面的选择符进行匹配。也就是说选择符与他们的查找方式没有关系。弄清楚这个就不会被不一样的组合混淆了。