[CSS] first-child选择器的一点理解

在W3school上的解释是这样的:

first-child选择器:选择属于其父元素的首个子元素的每个<p>元素,并为其设置样式:

p:first-child
{
background-color: yellow;
}

这很容易产生一种误解,认为p:first-child是选中p元素的第一个子元素。

举例说明:

<div>
    <p>标题1的第一段</p>
    <p>标题1的第二段</p>
</div>

<div>
    <h2>标题2</h2>
    <p>标题2的第一段</p>
</div>

第一种写法

div:first-child {color:red;}

按照错误理解(p:first-child是选中p元素的第一个子元素),那应该选择div元素的第一个p元素,但它把div里的所有p元素都匹配了,说明这种理解是错误的。

正确理解是:只要div元素是它的父级的第一个子元素,就选中。第一个div元素是它父级body元素的第一个子元素,所以被选中;第二个div元素并不是第一个子元素,所以不被选中。

第二种写法

p:first-child {color:red;}

这里匹配了第一个div里的第一个p,但没有匹配第二个div里的p。

正确的理解应该是:只要p元素是它的父级的第一个子元素,就选中。

在第二个div中,p元素并不是它的父级div的第一个子元素,所以不能被选中。

备注:本人刚入门学习,如有理解的不对的地方,欢迎大家批评指正,感谢。

  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值