CSS3中:first-child和:first-of-child的区别_html/css_WEB-ITnose
程序员文章站
2022-05-21 20:06:41
...
CSS中加入了很多高级的选择器,能让我们方便的查找到元素,然后给查找到的元素设置样式,其中:first-child和:first-of-child看似只相差一个单词,但是却有不同的用法和意义,今天的这篇文章就给大家来说说:first-child和:first-of-child两个选择器的区别。
HTML代码
加入我们有这样的一段HTML代码:
第1个元素
第2个元素
第3个元素 第4个元素
CSS选择器
我们要查找其中的元素,如果使用下面的定义方法
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伪类,请看他的用法和讲解:
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) 也可以这样去理解。
本文系作者 问说网 授权问说网发表,并经问说网编辑,转载请注明出处和 本文链接。
推荐阅读
-
CSS3中的background-size(对响应性图片等比例缩放)_html/css_WEB-ITnose
-
css3的基础用法,新手必看哈(还有css3和jquery动画的对比)_html/css_WEB-ITnose
-
10_Android中通过HttpUrlConnection访问网络,Handler和多线程使用,读取网络html代码并显示在界面上,ScrollView组件的使用_html/css_WEB-ITnose
-
CSS3中弹性盒布局的最新版_html/css_WEB-ITnose
-
background-origin和background-clip的区别_html/css_WEB-ITnose
-
css3 翻转和旋转的区别_html/css_WEB-ITnose
-
html中size和maxlength的区别
-
CSS3:元素的边框、背景和大小_html/css_WEB-ITnose
-
浅析CSS3 中的 transition,transform,translate之间区别和作用
-
HTML中Get请求和Post请求的区别_html/css_WEB-ITnose