如何水平居中零宽度元素的文本?
How to horizontally center text of zero-width element?
正如您在下面的代码片段中看到的,左边框代表元素的中心。文本从边框右侧开始。
但是,我需要文本在边框上居中,同时保持零宽度。
所以我需要以某种方式将文本向左移动,但是 text-align: center
和 text-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> </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>
正如您在下面的代码片段中看到的,左边框代表元素的中心。文本从边框右侧开始。
但是,我需要文本在边框上居中,同时保持零宽度。
所以我需要以某种方式将文本向左移动,但是 text-align: center
和 text-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> </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>