0

0

如何让表格单元格中的文字显示在伪元素圆点之上?

碧海醫心

碧海醫心

发布时间:2026-02-05 23:09:39

|

543人浏览过

|

来源于php中文网

原创

如何让表格单元格中的文字显示在伪元素圆点之上?

通过为 `

` 设置 `z-index: 0` 建立层叠上下文,并将伪元素 `::before` 的 `z-index` 设为负值(如 `-1`),即可确保文字始终位于黄色圆点上方,解决遮挡问题。

在实现吉他指板(fretboard)可视化表格时,常需同时展示标记(如黄色圆点)和音符文字(如 "A")。但默认情况下,使用 ::before 伪元素绘制的圆点会自然覆盖单元格内的文本内容——这是因为伪元素默认参与父元素的层叠上下文,且未显式设置 z-index 时其堆叠顺序可能高于文本流内容。

关键解决方案在于主动控制层叠上下文与层级关系

  • ✅ 为 元素添加 position: relative 和 z-index: 0:这会创建一个新的层叠上下文(stacking context),使该单元格成为其子元素(包括伪元素和文本)的层叠参考容器;
  • ✅ 将 td.selected::before 的 z-index 设为 -1:使其明确位于该上下文的底层,而单元格内常规文本(作为“层叠级别 0”内容)自动显示在其上方;
  • ❌ 不要省略 z-index: 0 在 上:若仅设伪元素 z-index: -1 而父元素无层叠上下文,则负 z-index 可能将其推至整个页面背景层之下,导致不可见。

    以下是修正后的完整 CSS 与 HTML 示例:

    千问APP
    千问APP

    阿里最强大模型官方AI助手

    下载
    table {
      background: black;
      border-collapse: collapse;
    }
    td {
      position: relative;
      z-index: 0; /* 关键:创建层叠上下文 */
      width: 40px;
      height: 40px;
      text-align: center;
      color: transparent; /* 初始隐藏文字,hover 时再显示 */
      font-weight: bold;
    }
    td.selected::before {
      content: '';
      position: absolute;
      left: 50%;
      top: 15%;
      transform: translateX(-50%); /* 更精准居中 */
      background: yellow;
      width: 16px;
      height: 16px;
      border-radius: 50%;
      z-index: -1; /* 关键:置于文字下方 */
    }
    td.show {
      color: red; /* hover 或激活状态显示文字 */
    }
    A B C

    ? 额外提示

    • 使用 transform: translateX(-50%) 替代纯 left: 50% 可更精确水平居中圆点;
    • 若需支持多状态(如不同颜色/形状标记),建议用 CSS 自定义属性(--dot-color)配合 ::before 动态控制,提升可维护性;
    • 避免对 ::before 使用 z-index: 0 或正值——这反而可能再次遮挡文字,除非你刻意构建多层覆盖效果。

    该方案轻量、兼容性强(支持所有现代浏览器及 IE11+),无需 JavaScript,纯粹依靠 CSS 层叠规则达成语义清晰、视觉准确的指板交互表现。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

400

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

579

2023.08.10

CSS position定位有几种方式
CSS position定位有几种方式

有4种,分别是静态定位、相对定位、绝对定位和固定定位。更多关于CSS position定位有几种方式的内容,可以访问下面的文章。

81

2023.11.23

java连接字符串方法汇总
java连接字符串方法汇总

本专题整合了java连接字符串教程合集,阅读专题下面的文章了解更多详细操作。

7

2026.02.05

java中fail含义
java中fail含义

本专题整合了java中fail的含义、作用相关内容,阅读专题下面的文章了解更多详细内容。

8

2026.02.05

控制反转和依赖注入区别
控制反转和依赖注入区别

本专题整合了控制反转和依赖注入区别、解释、实现方法相关内容。阅读专题下面的文章了解更多详细教程。

10

2026.02.05

钉钉脑图插图教程合集
钉钉脑图插图教程合集

本专题整合了钉钉脑图怎么插入图片、钉钉脑图怎么用相关教程,阅读专题下面的文章了解更多详细内容。

20

2026.02.05

python截取字符串方法汇总
python截取字符串方法汇总

本专题整合了python截取字符串方法相关合集,阅读专题下面的文章了解更多详细内容。

2

2026.02.05

Java截取字符串方法合集
Java截取字符串方法合集

本专题整合了Java截取字符串方法汇总,阅读专题下面的文章了解更多详细操作教程。

1

2026.02.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.2万人学习

CSS教程
CSS教程

共754课时 | 27.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号