vertical-align:middle的居中細節調整


  使用vertical-align:middle可以讓行級元素垂直居中,但這個居中是以文字的中線來計算的,而文字的中線在不同的字體上不同,甚至相同的字體在不同的瀏覽器上顯示的都不同。

  所以直接使用vertical-align:middle很難完美居中,因此需要其它調整。

<!DOCTYPE html>
<style>
div {
  border:1px solid red;
  width:200px;
  height:100px;
  line-height:100px;
  text-align:center;
}
span {vertical-align:middle;}
#box {
  display:inline-block;
  width:100px;
  height:98px;
  background:#EEE;
}
</style>
<div>
  abc<span id="box"></span>def
</div>

  

  當容器內存在vertical-align:middle元素時,它們的中線會被對其到所在行的基線上。

  而所在行的基線未必是中線,基線與中線偏離的距離就是vertical-align:middle垂直居中時候出現的偏離距離。

  基線與中線的位置差異會受到字體、字形、字號,等影響。而且在不同瀏覽器上字體的渲染還存在差異,這樣就不容易計算具體的偏差。

  但我們可以取消掉基線和中線的位置差,做法是將字號改到0,也就是不在行中直接使用文本節點。

<!DOCTYPE html>
<style>
div {
  border:1px solid red;
  width:200px;
  height:100px;
  line-height:100px;
  text-align:center;
  font-size:0px;
}
span {
  vertical-align:middle;
  display:inline-block;
  font-size:1rem;
}
#box {
  width:100px;
  height:98px;
  background:#EEE;
}
</style>
<div>
  <span>abc</span><span id="box"></span><span>def</span>
</div>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM