CSS3 nth-child的使用,详解css中nth的作用,以及nth-child的兼容写法
:nth-child是css3的一个比较常用的选择器。它用于匹配属于其父元素中的子元素,不论元素的类型。 它的参数可以是数字、关键词或公式。下面讲介绍它的使用方法,
nth-child的使用
html结构如下:
<div class="demo"> <p>1</p> <p>2</p> <p>3</p> <p>4</p> </div>
只选取第2个元素
.demo p:nth-child(2){color:#f00} /*数字2为红色。参数只为数字,代表选取的是第几个元素,注意不是从0开始的*/
选取第2个及之后的元素
.demo p:nth-child(n+2){color:#f00} /*数字2,3,4为红色。n+数字,代表选取数字后面所有的元素*/
选取第2个及之前的元素
.demo p:nth-child(-n+2){color:#f00} /*数字1,2为红色。-n+数字,代表选取数字之前所有的元素*/
选择奇数的元素
.demo p:nth-child(odd){color:#f00} .demo p:nth-child(2n-1){color:#f00} /*数字1,3为红色。odd等同于2n-1的写法*/
选择偶数的元素
.demo p:nth-child(even){color:#f00} .demo p:nth-child(2n){color:#f00} /*数字2,4为红色。even等同于2n的写法*/
选择间隔为a,偏移为吧的元素
使用公式 (an + b)。描述:表示周期的长度,n 是计数器(从 0 开始),b 是偏移值 。
.demo p:nth-child(3n+2){color:#f00} /*数字2为红色。从2开始,间隔为3*/
办公资源网址导航 https://www.wode007.com
nth-child的兼容
通过:first-child属性:
.demo p:first-child{color:#f00;}/*选取第一个*/ .demo p:first-child+p+p{color:#f00;}/*选取第三个*/
通过>来实现
.demo>p+p{ color:#f00;}/*第2级之后的元素*/
通过jquery的js来实现
1 $(document).ready(function(){ 2 $(".demo p:nth-child(2)").css("color","#f00"); 3 }); 4 /*需要引入jquery文件*/
Css3其他类似选择器
:nth-of-type() 选择器 ——选择器匹配属于父元素的特定类型的第 N 个子元素的每个元素. n 可以是数字、关键词或公式。与:nth-child(n)不同的是后者与类型无关。
:first-of-type 选择器匹配属于其父元素的特定类型的首个子元素的每个元素。 提示:等同于 :nth-of-type(1)。
:last-of-type 选择器匹配属于其父元素的特定类型的最后一个子元素的每个元素。 提示:等同于 :nth-last-of-type(1)。
:only-of-type 选择器匹配属于其父元素的特定类型的唯一子元素的每个元素。
:nth-last-child(n) 选择器匹配属于其元素的第 N 个子元素的每个元素,不论元素的类型,从最后一个子元素开始计数。n 可以是数字、关键词或公式。 提示:请参阅 :nth-last-of-type() 选择器,该选择器选取父元素的第 N 个指定类型的子元素,从最后一个子元素开始计数。
:nth-last-of-type(n) 选择器匹配属于父元素的特定类型的第 N 个子元素的每个元素,从最后一个子元素开始计数。n 可以是数字、关键词或公式。 提示:请参阅 :nth-last-child() 选择器,该选择器选取父元素的第 N 个子元素,与类型无关,从最后一个子元素开始计数。
:last-child 选择器匹配属于其父元素的最后一个子元素的每个元素。 提示:p:last-child 等同于 p:nth-last-child(1)。