CSS3中:first-child和:first-of-child的区别
下面就说说first-child与first-of-type的区别:
first-child:父元素的第一个子元素且必须符合指定类型
first-of-type:父元素的符合指定类型的第一个子元素
当然,光看文字也是很难理解的,下面看看例子:
<div>
<p>第1行</p>
<p>第2行</p>
<p>第3行</p>
</div>
这种情况下,不管是p:first-of-type还是p:first-child,<p>第1行</p>都会被选中。
而如果是:
<div>
<i>第1行</i>
<p>第2行</p>
<p>第3行</p>
<p>第4行</p>
</div>
则p:first-of-type的话,<p>第2行</p>会被选中;
而p:first-child的话,将没有任何元素被选中!
2024-11-19 广告
你想问的是 CSS3中:first-child和:first-of-type的区别吧?
举个例子
<div class="box1">
<p>第1个元素</p>
<h1>第2个元素</h1>
<span>第3个元素</span>
<span>第4个元素</span>
</div>
<div class="box2">
<h1>第2个元素</h1>
<p>第1个元素</p>
<span>第3个元素</span>
<span>第4个元素</span>
</div>
在box1中想选中p标签可以用:first-child或者:first-of-type,
而在box2中想选中p标签只能用:first-of-type。
也就是说
:first-child 匹配的是某父元素的第一个子元素,可以说是结构上的第一个子元素,位置上必须是第一个。
:first-of-type 匹配的是该类型的第一个元素。位置上可以不是第一个。
<div>
<p>第1个元素</p>
<h1>第2个元素</h1>
<span>第3个元素</span>
<span>第4个元素</span></div>
不存在 first-of-child
CSS选择器
我们要查找其中的元素,如果使用下面的定义方法
p:first-child 匹配到的是p元素,因为p元素是div的第一个子元素;
h1:first-child 匹配不到任何元素,因为在这里h1是div的第二个子元素,而不是第一个;
span:first-child 匹配不到任何元素,因为在这里两个span元素都不是div的第一个子元素;
:first-child 匹配到的是p元素,因为在这里div的第一个子元素就是p。
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元素中的第一个。这里不再限制是第一个子元素了,只要是该类型元素的第一个就行了,当然这些元素的范围都是 属于同一级的,也就是同辈的。
上面应用的样式,有两个是匹配不到的,但是别慌张,CSS中还定义了:first-of-child伪类,请看他的用法和讲解:
总结
同样类型的选择器 :last-child 和 :last-of-type、:nth-child(n) 和 :nth-of-type(n) 也可以这样去理解。