当前位置:首页 > 文章列表 > 文章 > 前端 > CSS实现斑马纹表格的三种方法

CSS实现斑马纹表格的三种方法

2025-07-06 13:18:46 0浏览 收藏

最近发现不少小伙伴都对文章很感兴趣,所以今天继续给大家介绍文章相关的知识,本文《CSS实现斑马纹表格的三种技巧》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~

要实现斑马纹表格效果,可使用纯CSS的三种方法。1. 使用tr:nth-child(odd)和tr:nth-child(even),优点是写法简单但需注意表头及嵌套结构影响计数;2. 使用tr:nth-of-type(odd),更精准控制仅计算元素适用于复杂结构;3. 使用@for循环配合类名适合SCSS/Less预处理器优点是样式灵活但需手动或动态添加类名。不同场景选择不同方式以达到最佳效果。

CSS选择器实现斑马纹表格的三种方法

要实现斑马纹表格效果,也就是让表格的奇数行和偶数行有不同的背景色,CSS 提供了多种选择器可以完成这个任务。不需要 JavaScript,也不需要给每一行加额外类名,纯 CSS 就能搞定。

CSS选择器实现斑马纹表格的三种方法

下面介绍三种常用的实现方式,适用于不同场景和浏览器兼容性需求。

CSS选择器实现斑马纹表格的三种方法

使用 tr:nth-child(odd)tr:nth-child(even)

这是最常见也最直观的方式。利用 nth-child 伪类选择器,根据行号是奇数还是偶数来设置不同的样式。

tr:nth-child(odd) {
  background-color: #f2f2f2;
}

tr:nth-child(even) {
  background-color: #ffffff;
}
  • 优点:语义清晰,写法简单。
  • 注意点
    • 如果表格中有表头(),要注意 tr 的计数是否包含表头行。
    • 在嵌套表格或复杂结构中可能会选错行。

如果你希望只对 中的行生效,可以这样写:

CSS选择器实现斑马纹表格的三种方法
tbody tr:nth-child(odd) {
  background-color: #f2f2f2;
}

使用 tr:nth-of-type(odd) 更精准控制

nth-of-typenth-child 看起来差不多,但行为略有区别。nth-of-type 只会计算特定类型的子元素,比如只计算 类型的子元素。

tr:nth-of-type(odd) {
  background-color: #f2f2f2;
}
  • 适用场景:当表格结构中夹杂了其他类型元素(如
    或注释节点)时,更推荐使用 nth-of-type
  • 对比
    • nth-child 是按所有子元素顺序判断位置;
    • nth-of-type 只看当前标签类型的位置。

举个例子:

<table>
  <tr><td>Row 1</td></tr>
  <div>干扰项</div>
  <tr><td>Row 2</td></tr>
</table>

在这种结构下:

  • tr:nth-child(odd) 会选择第一个
    后面的 (因为它们分别是第1、3个子元素);
  • tr:nth-of-type(odd) 只会选到第一个 ,因为第二个 是第2个 tr 类型的元素。

使用 @for 循环配合类名(适合 SCSS/Less 预处理器)

如果你在用 Sass 或 Less 这样的 CSS 预处理器,还可以通过循环生成带类名的样式,实现更灵活的控制。

例如,在 SCSS 中:

@for $i from 1 through 10 {
  tr.row-#{$i} {
    background-color: if($i % 2 == 1, #f2f2f2, #ffffff);
  }
}

然后 HTML 中为每一行加上对应的类名:

<tr class="row-1">...</tr>
<tr class="row-2">...</tr>
<!-- 依此类推 -->
  • 优点:样式可定制性强,适合需要根据不同行数应用不同样式的复杂表格。
  • 缺点:需要手动添加类名,或者后端/前端动态生成;不适用于动态数据长度不确定的情况。

总的来说,这三种方法各有适用场景:

  • 想快速实现且结构简单 → 用 tr:nth-child(odd)
  • 表格结构较复杂或有干扰节点 → 改用 tr:nth-of-type(odd)
  • 使用预处理器并需要精细控制 → 结合类名 + 循环生成样式

基本上就这些方法,不复杂但容易忽略细节。

以上就是《CSS实现斑马纹表格的三种方法》的详细内容,更多关于的资料请关注golang学习网公众号!

Golang反射获取函数信息全解析Golang反射获取函数信息全解析
上一篇
Golang反射获取函数信息全解析
Win11触控优化技巧大全
下一篇
Win11触控优化技巧大全
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    509次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • AI边界平台:智能对话、写作、画图,一站式解决方案
    边界AI平台
    探索AI边界平台,领先的智能AI对话、写作与画图生成工具。高效便捷,满足多样化需求。立即体验!
    28次使用
  • 讯飞AI大学堂免费AI认证证书:大模型工程师认证,提升您的职场竞争力
    免费AI认证证书
    科大讯飞AI大学堂推出免费大模型工程师认证,助力您掌握AI技能,提升职场竞争力。体系化学习,实战项目,权威认证,助您成为企业级大模型应用人才。
    52次使用
  • 茅茅虫AIGC检测:精准识别AI生成内容,保障学术诚信
    茅茅虫AIGC检测
    茅茅虫AIGC检测,湖南茅茅虫科技有限公司倾力打造,运用NLP技术精准识别AI生成文本,提供论文、专著等学术文本的AIGC检测服务。支持多种格式,生成可视化报告,保障您的学术诚信和内容质量。
    176次使用
  • 赛林匹克平台:科技赛事聚合,赋能AI、算力、量子计算创新
    赛林匹克平台(Challympics)
    探索赛林匹克平台Challympics,一个聚焦人工智能、算力算法、量子计算等前沿技术的赛事聚合平台。连接产学研用,助力科技创新与产业升级。
    252次使用
  • SEO  笔格AIPPT:AI智能PPT制作,免费生成,高效演示
    笔格AIPPT
    SEO 笔格AIPPT是135编辑器推出的AI智能PPT制作平台,依托DeepSeek大模型,实现智能大纲生成、一键PPT生成、AI文字优化、图像生成等功能。免费试用,提升PPT制作效率,适用于商务演示、教育培训等多种场景。
    194次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码