【问题标题】: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;
  • 有趣的是你必须让它的宽度为零。绝对定位不起作用(因此您可以将线作为线性渐变背景)。伪元素为您提供正确的视觉解决方案,但屏幕阅读器用户可能永远不会听到这些轴标记。当然,这对他们对您的特定应用程序的理解可能有影响,也可能无关紧要,我不知道。

标签: css border text-align


【解决方案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>

      【讨论】:

        猜你喜欢
        • 2010-11-16
        • 2015-05-28
        • 2021-02-10
        • 2010-09-11
        • 2022-08-10
        相关资源
        最近更新 更多