时间:2020-12-13来源:www.pcxitongcheng.com作者:电脑系统城
在前端编程中我们经常用到nth-child选择符,它可以接受数值也可以接受odd,even等,今天翻阅精通CSS一书才想起它还可以接受一个表达式,类似4n+1,-2n+1等。那他们各自具体有什么用呢?适用的场景是什么呢?可能大家还不是很清楚,下面我们来根据实例具体了解下,他们的html结构如下:
1 2 3 4 5 6 7 8 |
< body > < a >1</ a > < a >2</ a > < a >3</ a > < a >4</ a > < a >5</ a > < a >6</ a > </ body > |
这个是很经常用到的变量,分别代表偶数和奇数
1 2 3 4 5 6 7 8 |
<style type= "text/css" > a:nth-child(even){ /*偶数字体为红色*/ color : red ; } a:nth-child(odd){ /*奇数字体大小为30px*/ font-size : 30px ; } </style> |
查阅浏览器也发现确实是跟我们预料的一样,如下:
选择单元素,元素根据给的数值来匹配,从1开始计数,应该是最为常见的,如下:
1 2 3 4 5 6 |
<style type= "text/css" > a:nth-child( 3 ){ /*选择第三个元素的数据进行处理*/ color : red ; font-size : 30px ; } </style> |
结果也是如我们所料的:
这个表达式形式接触的比较少,应该怎么去处理呢?其实他也是很简单的,只要把n从0开始计数,再计算整个表达式的值,匹配文档,如果没有匹配成功的,则停止 例如nth-child(2n+1)是怎么匹配现在的文档呢,当n=0,2n+1=1,存在则继续匹配。n=1,2n+1=3,也存在,n=2,2n+1=5,还是存在,n=3,2n+1=7,此时已无法匹配成功了,所以起作用的元素应该是1,3,5行,让我们看下浏览器结果是否如我们所料:
果然只有1,3,5
那如果是-n呢,例如-n+2,其实也是类似的,当n=0,-n+2=2,存在继续匹配,当n=1,-n+2=1还是存在,当n=0,-n+2=0不存在结束匹配,所以起作用的元素应该是1,2行,看下结果:
所以我们可以利用这个来匹配前几个元素,当然你设计的表达式不同,能匹配到的元素也是不同的。
:nth-of-type他的取值跟上面是类似的,那差别在哪呢?当页面元素变得复杂得时候就可以看出来了,下面改下html结构,如下:
1 2 3 4 5 6 7 8 9 10 |
< body > < a >a1</ a > < p >p1</ p > < a >a2</ a > < p >p2</ p > < a >a3</ a > < p >p3</ p > < a >a4</ a > < p >p4</ p > </ body > |
可以发现这里面多了p标签,那么当我们添加下列css样式时会发生什么呢?
1 2 3 4 5 6 |
<style type= "text/css" > a:nth-child( 2 ){ color : red ; font-size : 30px ; } </style> |
我想很多人可能会说a2变红变大,但其实是吗?看下结果:
结果就是毫无变化,为什么呢?因为a:nth-child(2)指得是既是a标签又是父元素中排第二的子元素,在我们的结构中,父元素中排第二的子元素应该是p1所对应的标签。那么要怎么实现a2变红变大呢?这里就要引入容易混淆的a:nth-of-type(2),因为他指的就是既是a标签又是父元素中在所有a元素里排第二的子元素,那不就正和我意了?让我们看下结果是否如我们所愿?
1 2 3 4 5 6 |
<style type= "text/css" > a:nth-of-type( 2 ){ color : red ; font-size : 30px ; } </style> |
这才是我们所想的。
首先总结了nth-child的多种取值,注意单数值是从1开始计数,如果是数值表达式,n是从0开始计数
介绍了容易混淆的nth-of-type,nth-of-type是指在当前指定类型元素里的排序,而nth-child是在所有元素之间的排序
到此这篇关于总结下常用的nth-child选择符 的文章就介绍到这了
2023-03-06
css3鼠标滑过实现动画线条边框2023-03-06
css scroll-snap控制滚动元素的实现2023-03-06
CSS实现多层嵌套列表自动编号的示例代码传统的灰色纯色边框你是不是觉得太难看了?你是否想设计一些精美的边框,例如渐变、圆角、彩色的边框?那你来对地方了,本文将介绍如何用纯CSS就能实现具有渐变和圆角的彩色边框...
2023-03-06
今天给大家带来一个如何实现圆角三角形的方案,这个方案虽然可以实现,但是也是借助拼凑等方式来实现的,假如想一个div来实现圆角三角形,还是比较困难的。之前文章讲了如何实现对话框,里面介绍了三角形的实现方式。今天讲讲...
2023-03-06