CSS的选择器 :first-child和:last-child

简介: CSS的选择器 :first-child和:last-child

 转载!!!原文地址:关于Css的选择器 :first-child和:last-child所踩过的坑_饼小将的博客-CSDN博客

last-child选择器查了下W3C的文档发现我想的没那么简单。

就拿:last-child举例,文档中对其的解释是:

指定属于其父元素的最后一个子元素的 p 元素的背景色

什么意思呢?我详细说明一下:

假如是 div:last-child 那么该选择器最终选择的元素是 : 对所有div标签的父元素的其最后一个子元素div 设置样式,也就是说,其父元素的最后一个子元素必须是div 才能设置样式

这里有个非常重要需要注意的地方:div:last-child中div后面不能有空格,有了空格后意思就变了

不懂?举几个简单的例子就懂了:

Html结构

image.gif编辑

Css

image.gif编辑

可以先不看效果,自己想一下那个标签会被设置样式

效果:

image.gif编辑

有些人可能会疑惑,为什么p标签没有被设置样式。

因为根据刚才的释义div:last-child中规定了最后的那个子元素必须是div,否则无效。

详细过程:根据div:last-child 浏览器会获取所有的div。其中浏览器获取到了id为a2,a3,a4,a5的div标签,他们的父元素都是a1,而a1的最后一个子元素是p,不是div,所以无效

而为什么a6的div也被设置样式了呢?

因为a6也是div,其父元素body的最后一个子元素是div 也就是a6 所以被设置样式了

——————————————————————————————————————————

好的,现在我们加上空格:div :last-child 看看会发生什么样的情况(html结构不变)

image.gif编辑

效果如下:

image.gif编辑

会发现,a6 的div 不再有绿色背景。

为什么呢?因为加了空格,空格就相当于后代选择器,所以div :last-child的含义是指定了以div 标签为目标,其最后一个子元素设置样式,而且不会有元素名的限制(比如说一定要div标签等)。

而如果这样写:div div:last-child 含义就是以div 标签为目标,其里面的最后一个子元素,且该必须是div 元素,为其设置样式。

就是说如果在a6里面加入一些标签,如果是div :last-child(有空格),则不会对最后的一个子元素做限制:

image.gif编辑

效果:

image.gif编辑

很明显,a6中的最后一个子元素(p元素)被渲染

这里可以做个总结:

有name1 name2:last-child ,其中紧挨着:last-child的name2是用来对最后一个子元素名作限制的,也可以不写直接用name1 :last-child ,这样name2为空,代表不对元素名作限制,一般都是这样的用法,直接选择最后一个子元素,这样比较直观,也容易懂

相关文章
|
4月前
|
前端开发
CSS:高级选择器
CSS:高级选择器
62 1
|
4月前
|
前端开发 JavaScript
CSS:基础选择器
CSS:基础选择器
64 1
|
2月前
|
存储 移动开发 前端开发
高效的 HTML 与 CSS 编写技巧,涵盖语义化标签、文档结构优化、CSS 预处理、模块化设计、选择器优化、CSS 变量、媒体查询等内容
本文深入探讨了高效的 HTML 与 CSS 编写技巧,涵盖语义化标签、文档结构优化、CSS 预处理、模块化设计、选择器优化、CSS 变量、媒体查询等内容,旨在提升开发效率、网站性能和用户体验。
66 5
|
2月前
|
前端开发 JavaScript UED
深入理解与应用 CSS 伪类选择器
【10月更文挑战第23天】通过以上对 CSS 伪类选择器的深入探讨,我们可以更好地理解和应用它们,为网页设计和开发带来更丰富、更灵活的样式效果。同时,要注意在实际应用中根据具体情况合理选择和使用伪类选择器,以达到最佳的设计效果和用户体验。
64 2
|
4月前
|
前端开发 JavaScript 容器
谁动了我的选择器?深入理解CSS选择器优先级
该文章详细解释了CSS选择器的工作原理,包括不同种类选择器的权重计算规则,并通过实例说明了如何解决样式冲突问题,确保所需的样式能够正确应用到目标元素上。
|
4月前
|
前端开发
前端基础(四)_CSS层叠样式表_什么是css_css样式的引入方式_样式表的优先级_样式选择器
本文详细介绍了CSS(层叠样式表)的基本概念、语法规则、引入方式、样式表的优先级和样式选择器。文章解释了CSS的作用,展示了如何在HTML中通过行内样式、内部样式和外部样式引入CSS,讨论了不同CSS选择器的优先级和如何确定最终的样式应用。此外,还强调了使用`!important`规则时的优先级高于行内样式。
155 1
|
3月前
|
前端开发
CSS常见的选择器
CSS常见的选择器
30 0
|
4月前
|
前端开发 JavaScript
【CSS】选择器
【CSS】选择器
|
5月前
|
前端开发
CSS3选择器
【8月更文挑战第23天】CSS3选择器。
42 1
|
5月前
|
前端开发
CSS中的层级选择器&伪类选择器和伪元素选择器
CSS中的层级选择器&伪类选择器和伪元素选择器