CSS3中nth-child与nth-of-type的区别是什么(CSS3,nth-child,nth-of-type,开发技术)

时间:2024-05-08 08:30:24 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

这篇文章主要介绍“CSS3中nth-child与nth-of-type的区别是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“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,若不是,则选择失败。

文字未免听起来比较晦涩,便于理解,这里附上一个小例子:

<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>demo</title></head><style>.demoli:nth-child(2){color:#ff0000;}.demoli:nth-of-type(2){color:#00ff00;}</style><body><div><ulclass="demo"><p>zero</p><li>one</li><li>two</li></ul></div></body></html>

结果如下:

CSS3中nth-child与nth-of-type的区别是什么

上面这个例子,.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结构:

<ulclass="demo"><p>firstp</p><li>firstli</li><li>secondli</li><p>secondp</p></ul>

结果:

CSS3中nth-child与nth-of-type的区别是什么

如上可见,在他们之前不指定标签类型,: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的所有元素

关于“CSS3中nth-child与nth-of-type的区别是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。

本文:CSS3中nth-child与nth-of-type的区别是什么的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:jQuery面试题有哪些下一篇:

17 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18