如何将零宽度元素的文本水平居中?

Posted

技术标签:

【中文标题】如何将零宽度元素的文本水平居中?【英文标题】:How to horizontally center text of zero-width element? 【发布时间】:2021-12-21 21:16:41 【问题描述】:

在下面的 sn-p 中可以看到,左边框代表元素的中心。文本从边框右侧开始。

但是,我需要文本以边框为中心,同时保持零宽度。

所以我需要以某种方式将文本向左移动,但 text-align: centertext-align: middle 没有效果。

我无法翻译整个元素,因为这样边框会被翻译到错误的位置。

此元素的用途是作为图表水平轴的刻度线。

div 
  width: 0;
  border-left: 1px solid black;
<div>foo</div>

【问题讨论】:

使用::before::after伪元素怎么样? 也可以试试text-indent: -10px; 有趣的是你必须让它的宽度为零。绝对定位不起作用(因此您可以将线作为线性渐变背景)。伪元素为您提供正确的视觉解决方案,但屏幕阅读器用户可能永远不会听到这些轴标记。当然,这对他们对您的特定应用程序的理解可能有影响,也可能无关紧要,我不知道。 【参考方案1】:

感谢Sato Takeru 的评论,我决定使用伪元素。

div 
  width: 0;
  border-left: 1px solid black;


div::before 
  position: absolute;
  text-align: center;
  content: 'foo';
  width: 4em;
  transform: translateX(-2em);
<div> </div>

【讨论】:

【参考方案2】:

span 
  position: relative;
  width: 0;


span:after
  content: '';
  position: absolute;
  width: 1px;
  height: 100%;
  background: #000;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
<span>foo</span>

【讨论】:

【参考方案3】:

flexbox 是这里最简单的方法:

div 
  width: 0;
  border-left: 1px solid black;
  display:flex;
  justify-content:center;
<div>foo</div>

【讨论】:

以上是关于如何将零宽度元素的文本水平居中?的主要内容,如果未能解决你的问题,请参考以下文章

css绝对定位如何水平居中?

宽度不固定元素水平居中

如何在 100% 宽度的 div 内水平居中绝对定位的元素? [复制]

水平居中元素文本对齐中心不起作用

CSS水平居中+垂直居中+水平/垂直居中的方法总结

CSS水平垂直居中常见方法总结2