CSS 中 nth-child 选择器的详细用法和示例

CSS 中的 :nth-child(an+b) 是一个"结构伪类"选择器,它按照元素在 同一父元素下所有同级子节点的"绝对序号" 来匹配,而不是只看"同类"元素。

语法公式:

css 复制代码
:nth-child(an + b)   /* a、b 为整数,n 从 0 开始递增 */

常用关键字/公式速查

  • odd  等价于 2n+1
  • even  等价于 2n
  • 3n+1  第 1、4、7... 项
  • -n+5  前 5 项(n=0→5, n=1→4 ... n=5→0,之后为负不再匹配)

完整规则与示例

  1. 序号从 1 开始计数,且先按位置找,再核对类型

    若第 n 个子节点不是写在选择器前面的类型,则匹配失败。

    例:div:nth-child(3) 只有当父元素的第 3 个子节点同时是 div 时才生效。

  2. 典型用法

    表格隔行变色

    css 复制代码
    tr:nth-child(even) { background:#f5f5f5; }  /* 偶数行 */
    tr:nth-child(odd)  { background:#fff; }    /* 奇数行 */

    列表前 3 项高亮

    css 复制代码
    li:nth-child(-n+3) { color: red; }

    每 3 张图片去掉右边距

    css 复制代码
    .gallery img:nth-child(3n) { margin-right: 0; }
  3. :nth-of-type 的区别
    :nth-child 先数所有兄弟 ,再核对类型;
    :nth-of-type 只数同类兄弟 ,再取第 n 个。

    示例 HTML:

    html 复制代码
    <article>
      <p>P1</p>
      <div>D1</div>
      <p>P2</p>
    </article>
    • p:nth-child(3) 能命中"P2",因为第 3 个子节点就是 p。
    • p:nth-child(2) 不会命中任何元素,因为第 2 个子节点是 div。
    • p:nth-of-type(2) 会命中"P2",它只数 p 的同类顺序。
  4. 性能提示

    避免过度嵌套(如 html body div.wrapper ... :nth-child),保持选择器扁平;

    对于大数据列表,优先在父级一次性写规则,不要给每项再加类。

掌握"先定位序号、再核对类型"的核心思想,就可以用 :nth-child 一套公式搞定条纹、循环、切片等各种排版需求,而无需额外类名或脚本。

相关推荐
华玥作者19 小时前
[特殊字符] VitePress 对接 Algolia AI 问答(DocSearch + AI Search)完整实战(下)
前端·人工智能·ai
Mr Xu_19 小时前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠19 小时前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
lang2015092820 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
好家伙VCC20 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
未来之窗软件服务21 小时前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
嘿起屁儿整21 小时前
面试点(网络层面)
前端·网络
VT.馒头21 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
phltxy1 天前
Vue 核心特性实战指南:指令、样式绑定、计算属性与侦听器
前端·javascript·vue.js
Byron07071 天前
Vue 中使用 Tiptap 富文本编辑器的完整指南
前端·javascript·vue.js