首页 > 解决方案 > 如何在行高内将文本对齐到中间

问题描述

我想把一个大字符放在垂直和水平的中心对齐。这是我的风格和结果

div {
  border: 1px solid black;
  border-radius: 50%;
  width: 300px;
  height: 300px;
  margin: 150px auto;
  text-align: center;
  line-height: 300px;
}

span {
  display: inline-block;
  background-color: burlywood;
  line-height: 0.5;
  vertical-align: middle;
  font-size: 300px;
}
<div><span>s</span></div>

这是结果

我怎样才能把's'放在中间?

标签: cssalignment

解决方案


看起来css的区别在于lower case字母:

div {
  border: 1px solid black;
  border-radius: 50%;
  width: 300px;
  height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

span {
  display: inline-block;
  vertical-align: middle;
  background-color: burlywood;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 50%;
  height: 50%;
  font-size: 10em;
}
<div><span>S</span></div>
<div><span>s</span></div>
<div><span>M</span></div>
<div><span>m</span></div>


推荐阅读