CSS中加入了不少高级的选择器,能让咱们方便的查找到元素,而后给查找到的元素设置样式,其中:first-child和:first-of-child看似只相差一个单词,可是却有不一样的用法和意义,今天的这篇文章就给你们来讲说:first-child和:first-of-child两个选择器的区别。 css
HTML代码
加入咱们有这样的一段HTML代码: html
<div>
<p>第1个元素</p>
<h1>第2个元素</h1>
<span>第3个元素</span>
<span>第4个元素</span>
</div>
CSS选择器
咱们要查找其中的元素,若是使用下面的定义方法 css3
- p:first-child 匹配到的是p元素,由于p元素是div的第一个子元素;
- h1:first-child 匹配不到任何元素,由于在这里h1是div的第二个子元素,而不是第一个;
- span:first-child 匹配不到任何元素,由于在这里两个span元素都不是div的第一个子元素;
- :first-child 匹配到的是p元素,由于在这里div的第一个子元素就是p。
上面应用的样式,有两个是匹配不到的,可是别慌张,CSS中还定义了:first-of-child伪类,请看他的用法和讲解: spa
- p:first-of-type 匹配到的是p元素,由于p是div的全部为p的子元素中的第一个,事实上这里也只有一个为p的子元素;
- h1:first-of-type 匹配到的是h1元素,由于h1是div的全部为h1的子元素中的第一个,事实上这里也只有一个为h1的子元素;
- span:first-of-type 匹配到的是第三个子元素span。这里div有两个为span的子元素,匹配到的是第一个。
- :first-of-type 匹配到的是p元素
总结
- :first-child 匹配的是某父元素的第一个子元素,能够说是结构上的第一个子元素。
- :first-of-type 匹配的是该类型的第一个,类型是指什么呢,就是冒号前面匹配到的东西,好比 p:first-of-type,就是指全部p元素中的第一个。这里再也不限制是第一个子元素了,只要是该类型元素的第一个就好了,固然这些元素的范围都是 属于同一级的,也就是同辈的。
一样类型的选择器 :last-child 和 :last-of-type、:nth-child(n) 和 :nth-of-type(n) 也能够这样去理解。 code
本文系做者
问说网 受权问说网发表,并经问说网编辑,转载请注明出处和
本文连接。