百科狗-知识改变命运!
--

:only-child - 仅有的一个子元素 - css 结构性伪类选择器

梵高1年前 (2023-11-21)阅读数 33#技术干货
文章标签元素

:only-child

版本:CSS3

:nth-child(an+b)这个 CSS 伪类首先找到所有当前元素的兄弟元素,然后按照位置先后顺序从1开始排序,选择的结果为CSS伪类:nth-child括号中表达式(an+b)匹配到的元素集合(n=0,1,2,3...)

  • 0n+3 或简单的 3 匹配第三个元素。
  • 1n+0 或简单的 n 匹配每个元素。(兼容性提醒:在 Android 浏览器 4.3 以下的版本 n 和 1n 的匹配方式不一致。1n 和 1n+0 是一致的,可根据喜好任选其一来使用。)
  • 2n+0 或简单的 2n 匹配位置为 2、4、6、8...的元素(n=0时,2n+0=0,第0个元素不存在,因为是从1开始排序)。你可以使用关键字 even 来替换此表达式。
  • 2n+1 匹配位置为 1、3、5、7...的元素。你可以使用关键字 odd 来替换此表达式。
  • 3n+4 匹配位置为 4、7、10、13...的元素。
  • a 和 b 都必须为整数,并且元素的第一个子元素的下标为 1。换言之就是,该伪类匹配所有下标在集合{an + b; n = 0, 1, 2,...}中的子元素。另外需要特别注意的是,an 必须写在 b 的前面,不能写成 b+an 的形式。

语法:

E:nth-child(n){sRules}

匹配父元素中的第n个子元素。参数是元素的索引。索引从1开始。n可以是一个数字,一个关键字,或者一个公式。

:nth-child(an+b)这个CSS 伪类首先找到所有当前元素的兄弟元素,然后按照位置先后顺序从1开始排序,选择的结果为CSS伪类:nth-child括号中表达式(an+b)匹配到的元素集合(n=0,1,2,3...)。示例:

  • 0n+3或简单的3匹配第三个元素。
  • 1n+0或简单的n匹配每个元素。(兼容性提醒:在 Android 浏览器 4.3 以下的版本n1n的匹配方式不一致。1n1n+0是一致的,可根据喜好任选其一来使用。)
  • 2n+0或简单的2n匹配位置为 2、4、6、8...的元素(n=0时,2n+0=0,第0个元素不存在,因为是从1开始排序)。你可以使用关键字even来替换此表达式。
  • 2n+1匹配位置为 1、3、5、7...的元素。你可以使用关键字odd来替换此表达式。
  • 3n+4匹配位置为 4、7、10、13...的元素。

ab都必须为整数,并且元素的第一个子元素的下标为 1。换言之就是,该伪类匹配所有下标在集合{an + b; n = 0, 1, 2,...}中的子元素。另外需要特别注意的是,an必须写在b的前面,不能写成b+an的形式。

选择器示例

表格中的举例:
  • tr:nth-child(2n+1):表示HTML表格中的奇数行。
  • tr:nth-child(odd):表示HTML表格中的奇数行。
  • tr:nth-child(2n):表示HTML表格中的偶数行。
  • tr:nth-child(even):表示HTML表格中的偶数行。

举例:

  • span:nth-child(0n+1):表示子元素中第一个且为span的元素,与:first-child选择器作用相同。
  • span:nth-child(1):表示父元素中子元素为第一的并且名字为span的标签被选中。
  • span:nth-child(-n+3):匹配前三个子元素中的span元素。

浏览器支持

IE9+以及新版浏览器都支持:nth-child()

例子

  • E:nth-child(n)匹配父元素的第n个子元素E,假设该子元素不是E,则选择符无效,但n会继续递增。
  • 要使该属性生效,E元素必须是某个元素的子元素,E的父元素最高是,即E可以是的子元素
  • 该选择符允许使用一个乘法因子(n)来作为换算方式,比如我们想选中所有的偶数子元素E,那么选择符可以写成:E:nth-child(2n)

使用E:nth-child(n)实现奇偶:

因为(n)代表一个乘法因子,可以是0,1,2,3,...,所以(2n)换算出来会是偶数,而(2n+1)换算出来会是奇数

li:nth-child(2n){color:#f00;}   /*偶数*/
li:nth-child(2n+1){color:blue;} /*奇数*/ 
  • 列表项一
  • 列表项二
  • 列表项三
  • 列表项四
  • 列表项一
  • 列表项二
  • 列表项三
  • 列表项四
.demo1 li:nth-child(2n){color:#f00;}.demo1 li:nth-child(2n+1){color:blue;}

使用odd,even实现奇偶:

关键字odd代表奇数,even代表偶数

li:nth-child(even){color:#f00;}  /*偶数*/
li:nth-child(odd){color:blue;}   /*奇数*/ 
  • 列表项一
  • 列表项二
  • 列表项三
  • 列表项四
.demo2 li:nth-child(even){color:#f00;}.demo2 li:nth-child(odd){color:blue;}
  • 列表项一
  • 列表项二
  • 列表项三
  • 列表项四

注意

E:nth-child(n)会选择父元素的第n个子元素E,如果第n个子元素不是E,则是无效选择符,但n会递增。

第1个p

第2个p

第1个span

第3个p

第2个span

第4个p

第5个p

p:nth-child(3){color:#f00;}

第三个

字体颜色不会是红色,p:nth-child(3)就不会命中任何一个元素。

第1个p

第2个p

第1个span

第3个p

第2个span

第4个p

第5个p

.demo3 p:nth-child(3){color:#f00;}

第1个p

第2个p

第1个span

第3个p

第2个span

第4个p

第5个p

p:nth-child(4){color:#f00;}

这时你以为会命中第4个p,但其实命中的却是第3个p,因为它是第4个子元素

第1个p

第2个p

第1个span

第3个p

第2个span

第4个p

第5个p

.demo4 p:nth-child(4){color:#f00;}

保险方式

假设不确定第1个子元素是否为E,但是又想命中第1个E,应该这样写:

p:first-of-type{color:#f00;}

//或者这样写:

p:nth-of-type(1){color:#f00;}

:only-child - 仅有的一个子元素 - css 结构性伪类选择器

参考:first-of-type:nth-of-type()

span:nth-child(2n+1), without an <em> among the child elements.

children 1, 3, 5, and 7 are selected.

span 1! span 2 span 3! span 4 span 5! span 6 span 7!

span:nth-child(2n+1), with an <em> among the child elements.

children 1, 5, and 7 are selected.
3 is used in the counting because it is a child, but it isn't selected because it isn't a <span>.

span! span this is an `em`. span span! span span! span

span:nth-of-type(2n+1), with an <em> among the child elements.

children 1, 4, 6, and 8 are selected.
3 isn't used in the counting or selected because it is an <em>, not a <span>, and nth-of-type only selects children of that type. the <em> is completely skipped over and ignored.

span! span this is an `em`. span! span span! span span!
//CSS html { font-family: sans-serif; } span, div em { padding: 5px; border: 1px solid green; display: inline-block; margin-bottom: 3px; } .first span:nth-child(2n+1), .second span:nth-child(2n+1), .third span:nth-of-type(2n+1) { background-color: lime; }

鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com

免责声明:我们致力于保护作者版权,注重分享,当前被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!邮箱:344225443@qq.com)

图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)