博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
深入理解css3中nth-child和 nth-of-type的区别
阅读量:6957 次
发布时间:2019-06-27

本文共 1395 字,大约阅读时间需要 4 分钟。

在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,若不是,则选择失败。
文字未免听起来比较晦涩,便于理解,这里附上一个小例子:
    
demo

    zero

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

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

    first p

  • first li
  • second li
  • second p

结果:

如上可见,在他们之前不指定标签类型,: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 元素指定两种不同的背景色:
p:nth-of-type(odd){background:#ff0000;}p:nth-of-type(even){background:#0000ff;}

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

使用公式 (an + b)。描述:表示周期的长度,n 是计数器(从 0 开始),b 是偏移值。

在这里,我们指定了下标是 3 的倍数的所有 p 元素的背景色:

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

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

转载地址:http://ikmil.baihongyu.com/

你可能感兴趣的文章
【Android】3.6 地图基本控制方法
查看>>
浏览器左下角提示网页上有错误解决方法
查看>>
Yii2 配置yii2-redis扩展
查看>>
html5 标签书写的规范
查看>>
文件包含漏洞
查看>>
java导出Excel工具类
查看>>
malloc calloc realloc,new区别联系以及什么时候用
查看>>
用ES6巧妙的解决传统面试中的算法小问题!
查看>>
php socket 编程(一)
查看>>
SDUT 简单枚举类型——植物与颜色
查看>>
Sicily Pair
查看>>
Windows 下配置Git
查看>>
CSS3 三角形运用
查看>>
简单工厂模式
查看>>
Vue基于vue-quill-editor富文本编辑器使用心得
查看>>
Linux下MySQL链接被防火墙阻止
查看>>
HTML5触摸事件(touchstart、touchmove和touchend)
查看>>
[BZOJ] 1003 [ZJOI2006]物流运输
查看>>
Vue项目中的mock数据
查看>>
关于Scott用户
查看>>