如何将零宽度元素的文本水平居中?
Posted
技术标签:
【中文标题】如何将零宽度元素的文本水平居中?【英文标题】:How to horizontally center text of zero-width element? 【发布时间】:2021-12-21 21:16:41 【问题描述】:在下面的 sn-p 中可以看到,左边框代表元素的中心。文本从边框右侧开始。
但是,我需要文本以边框为中心,同时保持零宽度。
所以我需要以某种方式将文本向左移动,但 text-align: center
和 text-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>&nbsp;</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>
【讨论】:
以上是关于如何将零宽度元素的文本水平居中?的主要内容,如果未能解决你的问题,请参考以下文章