CSS3选择器:nth-child和:nth-of-type之间的差异

咋一看,:nth-child和:nth-of-type 比较相似,但是两者区别还是比较大的。
先来看他们相似的地方:
<!--:nth-child-->
<style type="text/css">
    p{border:1px solid red;height:20px;}
    p:nth-child(2){background:blue;}
</style>
<!--:nth-of-type-->
<style type="text/css">
    p{border:1px solid red;height:20px;}
    p:nth-of-type(2){background:blue;}
</style>
<body>
    <p>p1</p>
    <p>p2</p><!--选中这个-->
</body>

两个选择的效果图相同,如下图: 
这里写图片描述

但是在两个P标签前面加一个span标签,则两则选择的对象就不一样:

<body>
    <span>span</span>
    <p>p1</p>
    <p>p2</p><!--选中这个-->
</body>

效果如下: 
:nth-child(2)的效果 
:nth-child(2)

:nth-of-type(2)的效果 
:nth-of-type(2)

由效果图看出两则区别,用口水话解释下:

E:nth-child(2)有两个约束: 
1、父级元素下的第二个元素 
2、并且第二元素必须是E元素

E:nth-of-type(2)有一个约束: 
1、父级元素下的第二个E元素,也就是说不管E元素前面有多少个其他元素,它只会找到第二个E元素

原文链接:CSS3选择器:nth-child和:nth-of-type之间的差异_huang_xiao_wei的博客-CSDN博客icon-default.png?t=LA92https://blog.csdn.net/huang_xiao_wei/article/details/53412805

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值