经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » CSS » 查看文章
总结下常用的nth-child选择符 _CSS教程_CSS
来源:jb51  时间:2020/12/14 17:00:32  对本文有异议

前言

在前端编程中我们经常用到nth-child选择符,它可以接受数值也可以接受odd,even等,今天翻阅精通CSS一书才想起它还可以接受一个表达式,类似4n+1,-2n+1等。那他们各自具体有什么用呢?适用的场景是什么呢?可能大家还不是很清楚,下面我们来根据实例具体了解下,他们的html结构如下:

  1. <body>
  2. <a>1</a>
  3. <a>2</a>
  4. <a>3</a>
  5. <a>4</a>
  6. <a>5</a>
  7. <a>6</a>
  8. </body>

nth-child(even)和nth-child(odd)

这个是很经常用到的变量,分别代表偶数和奇数

  1. <style type="text/css">
  2. a:nth-child(even){/*偶数字体为红色*/
  3. color: red;
  4. }
  5. a:nth-child(odd){/*奇数字体大小为30px*/
  6. font-size: 30px;
  7. }
  8. </style>

查阅浏览器也发现确实是跟我们预料的一样,如下:

nth-child(1)

选择单元素,元素根据给的数值来匹配,从1开始计数,应该是最为常见的,如下:

  1. <style type="text/css">
  2. a:nth-child(3){/*选择第三个元素的数据进行处理*/
  3. color: red;
  4. font-size: 30px;
  5. }
  6. </style>

结果也是如我们所料的:

nth-child(2n+1)

这个表达式形式接触的比较少,应该怎么去处理呢?其实他也是很简单的,只要把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

:nth-of-type他的取值跟上面是类似的,那差别在哪呢?当页面元素变得复杂得时候就可以看出来了,下面改下html结构,如下:

  1. <body>
  2. <a>a1</a>
  3. <p>p1</p>
  4. <a>a2</a>
  5. <p>p2</p>
  6. <a>a3</a>
  7. <p>p3</p>
  8. <a>a4</a>
  9. <p>p4</p>
  10. </body>

可以发现这里面多了p标签,那么当我们添加下列css样式时会发生什么呢?

  1. <style type="text/css">
  2. a:nth-child(2){
  3. color: red;
  4. font-size: 30px;
  5. }
  6. </style>

我想很多人可能会说a2变红变大,但其实是吗?看下结果:

结果就是毫无变化,为什么呢?因为a:nth-child(2)指得是既是a标签又是父元素中排第二的子元素,在我们的结构中,父元素中排第二的子元素应该是p1所对应的标签。那么要怎么实现a2变红变大呢?这里就要引入容易混淆的a:nth-of-type(2),因为他指的就是既是a标签又是父元素中在所有a元素里排第二的子元素,那不就正和我意了?让我们看下结果是否如我们所愿?

  1. <style type="text/css">
  2. a:nth-of-type(2){
  3. color: red;
  4. font-size: 30px;
  5. }
  6. </style>

 

这才是我们所想的。

小结

首先总结了nth-child的多种取值,注意单数值是从1开始计数,如果是数值表达式,n是从0开始计数

介绍了容易混淆的nth-of-type,nth-of-type是指在当前指定类型元素里的排序,而nth-child是在所有元素之间的排序

到此这篇关于总结下常用的nth-child选择符 的文章就介绍到这了,更多相关nth-child选择符 内容请搜索w3xue以前的文章或继续浏览下面的相关文章,希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号