当前位置:Gxlcms > css > 关于CSS3中nth-child和nth-of-type的区别详解

关于CSS3中nth-child和nth-of-type的区别详解

时间:2021-07-01 10:21:17 帮助过:14人阅读

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,若不是,则选择失败。

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

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>demo</title>
  6. </head>
  7. <style>
  8. .demo li:nth-child(2){
  9. color: #ff0000;
  10. }
  11. .demo li:nth-of-type(2){
  12. color: #00ff00;
  13. }
  14. </style>
  15. <body>
  16. <p>
  17. <ul class="demo">
  18. <p>zero</p>
  19. <li>one</li>
  20. <li>two</li>
  21. </ul>
  22. </p>
  23. </body>
  24. </html>


结果如下:



上面这个例子,.demo li:nth-child(2)选择的是<li>one</li>节点,而.demo li:nth-of-type(2)则选择的是<li>two</li>节点。

但是如果在nth-child和 nth-of-type前不指定标签呢?

  1. .demo :nth-child(2){
  2. color: #ff0000;
  3. }
  4. .demo :nth-of-type(2){
  5. color: #00ff00;
  6. }


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

  1. <ul class="demo">
  2. <p>first p</p>
  3. <li>first li</li>
  4. <li>second li</li>
  5. <p>second p</p>
  6. </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 元素指定两种不同的背景色:

  1. p:nth-of-type(odd)
  2. {
  3. background:#ff0000;
  4. }
  5. p:nth-of-type(even)
  6. {
  7. background:#0000ff;
  8. }

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

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

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

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

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

总结


以上就是关于CSS3中nth-child和nth-of-type的区别详解的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行