来源:https://www.cnblogs.com/shuiyi/p/5597187.html
红色(line-height)为行框的顶部和底部,绿色(font-size)为字体的高度,蓝色为基线(字母x底部所在的水平线)
行内元素:
行内块元素:
该行框的顶部边缘对齐该行中最顶部元素的顶部边缘,底部边缘对齐该行中的最底部元素的底部边缘。因此父元素的行框会将儿子的所有内容都包裹起来。这也导致父元素的基线会根据儿子的垂直排列方式而发生变化。
现在,让我们迅速总结一下上面的重点:
有一个称为行框的区域。这是垂直对齐发生的区域。它有一个基线,一个文本框和一个顶部和底部边缘
有一些称为内联级元素的元素。它们都是会对齐的对象。他们有一个基线和一个顶部和底部边缘
vertical-align : middle;
将元素的顶部和底部之间的中心点,对齐父元素的基线之上x-height的1/2之处(x-height为字母x的字符高度)。
vertical-align : text-top/text-bottom;
text-top:将元素的顶部边缘,对齐到父元素的文本框的顶部边缘
text-bottom:将元素的底部边缘,对齐到父元素的文本框的底部边缘
vertical-align : top/bottom;
top:元素的顶部边缘对齐到父元素的顶部边缘
bottom:元素的底部边缘对齐到父元素的底部边缘
正如你所看到的,列表项坐在基线上。下面的一点空间,是文本的基线以下预留的depth。通过设置列表项目vertical-align: middle移动基线位置来清楚这个间隙。
如果垂直对齐没有表现出你要的效果,只需要问以下问题:
行框的基线以及顶部和底部边缘在哪里?
内联级元素的基线和顶部和底部边缘在哪里?
前端知识点回顾之重点篇——CSS中vertical align属性
原文:https://www.cnblogs.com/simpul/p/11020107.html