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

How to horizontally center text of zero-width element?

正如您在下面的代码片段中看到的,左边框代表元素的中心。文本从边框右侧开始。

但是,我需要文本在边框上居中,同时保持零宽度。

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

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

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

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

感谢 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>

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>

flexbox 是这里最简单的方法:

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