当前位置: 首页 > news >正文

深入理解css3中 nth-child 和 nth-of-type 的区别

在css3中有两个新的选择器可以选择父元素下对应的子元素,一个是:nth-child 另一个是:nth-of-type。 但是它们到底有什么区别呢?

其实区别很简单::nth-of-type为什么要叫:nth-of-type?因为它是以"type"来区分的。也就是说:ele:nth-of-type(n)是指父元素下第n个ele元素,
而ele:nth-child(n)是指父元素下第n个元素且这个元素为ele,若不是,则选择失败。
文字未免听起来比较晦涩,便于理解,这里附上一个小例子:
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>demo</title>
</head>
<style>
  .demo li:nth-child(2) {
    color: #ff0000;
  }

  .demo li:nth-of-type(2) {
    color: #00ff00;
  }
</style>
<body>
<div>
  <ul class="demo">
    <p>zero</p>
    <li>one</li>
    <li>two</li>
  </ul>
</div>
</body>
</html>
结果如下:
上面这个例子,.demo li:nth-child(2)选择的是<li>one</li>节点,而.demo li:nth-of-type(2)则选择的是<li>two</li>节点。
但是如果在nth-child和 nth-of-type前不指定标签呢?
<style>
  .demo :nth-child(2) {
    color: #ff0000;
  }

  .demo :nth-of-type(2) {
    color: #00ff00;
  }
</style>

这样又会是什么结果呢,看下html结构:

<ul class="demo">
  <p>first p</p>
  <li>first li</li>
  <li>second li</li>
  <p>second p</p>
</ul>
结果:

如上可见,在他们之前不指定标签类型,:nth-child(2) 选中依旧是第二个元素,无论它是什么标签。而 :nth-type-of(2) 选中了两个元素,分别是父级.demo中的第二个p标签和第二个li标签,由此可见,不指定标签类型时,:nth-type-of(2)会选中所有类型标签的第二个。

我们已经了解了nth-child和 nth-of-type的基本使用与区别,那么更进一步nth-of-type(n)与nth-child(n)中的n是什么呢?
nth-of-type(n)与nth-child(n)中的n可以是数字、关键词或公式。
数字:也就是上面例子的使用,就不做赘述。
关键词:Odd 、even
Odd 和 even 是可用于匹配下标是奇数或偶数的子元素的关键词
注意:第一个子元素的下标是 1
在这里,我们为奇数和偶数 p 元素指定两种不同的背景色:
<style>
  p:nth-of-type(odd) {
    background: #ff0000;
  }

  p:nth-of-type(even) {
    background: #0000ff;
  }
</style>

 公式:或者说是算术表达式

使用公式 (an + b)。描述:表示周期的长度,n 是计数器(从 0 开始),b 是偏移值。在这里,我们指定了下标是 3 的倍数的所有 p 元素的背景色:

<style>
  p:nth-of-type(3n+0) {
    background: #ff0000;
  }
</style>

若是 :nth-of-type(4n+2) 就是选择下标是4的倍数加上2的所有元素

转载于:https://www.cnblogs.com/peakleo/p/6232384.html

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 求最大公约数和最小公倍数
  • 方案撰写注意事项
  • Linux 常用命令使用方法大搜刮
  • 应用Hash函数(java描述)
  • 用java实现生产者和消费者问题
  • 【转】AngularJS 日期格式化 字典
  • Struts的线程安全问题
  • JSP中的pageEncoding和contentType的区别
  • 2016-wing的年度总结
  • java中split() replace() replaceAll()三个函数分析
  • SPOJ-COLONY - Linearian Colony!简单二分思想
  • msfconsole 控制台使用和操作
  • 数据库范式
  • sed awk grep三剑客常用
  • 数据库事务隔离级别
  • 【跃迁之路】【585天】程序员高效学习方法论探索系列(实验阶段342-2018.09.13)...
  • 2017前端实习生面试总结
  • AngularJS指令开发(1)——参数详解
  • Docker 1.12实践:Docker Service、Stack与分布式应用捆绑包
  • JavaScript设计模式与开发实践系列之策略模式
  • java中的hashCode
  • Kibana配置logstash,报表一体化
  • RedisSerializer之JdkSerializationRedisSerializer分析
  • SegmentFault 技术周刊 Vol.27 - Git 学习宝典:程序员走江湖必备
  • 阿里云Kubernetes容器服务上体验Knative
  • 从0搭建SpringBoot的HelloWorld -- Java版本
  • 树莓派 - 使用须知
  • 数据结构java版之冒泡排序及优化
  • 一个项目push到多个远程Git仓库
  • 蚂蚁金服CTO程立:真正的技术革命才刚刚开始
  • ​RecSys 2022 | 面向人岗匹配的双向选择偏好建模
  • ​经​纬​恒​润​二​面​​三​七​互​娱​一​面​​元​象​二​面​
  • ​油烟净化器电源安全,保障健康餐饮生活
  • #70结构体案例1(导师,学生,成绩)
  • #window11设置系统变量#
  • #控制台大学课堂点名问题_课堂随机点名
  • (cljs/run-at (JSVM. :browser) 搭建刚好可用的开发环境!)
  • (Matalb分类预测)GA-BP遗传算法优化BP神经网络的多维分类预测
  • (二)linux使用docker容器运行mysql
  • (四)c52学习之旅-流水LED灯
  • (转)用.Net的File控件上传文件的解决方案
  • (转载)(官方)UE4--图像编程----着色器开发
  • (轉貼) VS2005 快捷键 (初級) (.NET) (Visual Studio)
  • .360、.halo勒索病毒的最新威胁:如何恢复您的数据?
  • .gitignore文件使用
  • .NET 2.0中新增的一些TryGet,TryParse等方法
  • .NET MAUI Sqlite程序应用-数据库配置(一)
  • .NET与 java通用的3DES加密解密方法
  • .project文件
  • //TODO 注释的作用
  • /3GB和/USERVA开关
  • [ CTF ] WriteUp- 2022年第三届“网鼎杯”网络安全大赛(朱雀组)
  • [2016.7.Test1] T1 三进制异或
  • [383] 赎金信 js
  • [BJDCTF2020]EzPHP1