vertical-align:middle的居中细节调整
2014-08-12 14:40
375 查看
使用vertical-align:middle可以让行级元素垂直居中,但这个居中是以文字的中线来计算的,而文字的中线在不同的字体上不同,甚至相同的字体在不同的浏览器上显示的都不同。所以直接使用vertical-align:middle很难完美居中,因此需要其它调整。
当容器内存在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; } 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>
相关文章推荐
- vertical-align:middle的居中细节调整
- vertical-align: middle;垂直居中精髓
- 关于vertical-align:middle的不居中问题
- vertical-align:middle居中,Firefox中换行问题
- 小经验:display:table 和 vertical-align:middle 控制 块元素垂直居中
- 利用vertical-align:middle实现行内元素的水平垂直居中对齐
- vertical-align使图片垂直居中的小细节
- 利用vertical-align:middle实现行内元素的水平垂直居中对齐
- 行内盒子 上下居中的代码 vertical-align:middle;
- vertical-align:middle在表单,img与文字实现垂直居中问题
- CSS实现垂直居中,vertical-align:middle怎么用
- vertical-align: middle垂直居中
- 使用display:table-cell 和 vertical-align:middle 不定宽高图片居中于容器
- vertical-align:middle在表单,img与文字实现垂直居中问题
- 利用vertical-align:middle实现在整个页面居中
- 利用vertical-align:middle实现垂直居中对齐
- 利用vertical-align:middle垂直居中
- CSS中水平居中的inline-height 和 vertical-align:middle;
- [转]利用vertical-align:middle实现在整个页面居中
- vertical-align:middle图片或者按钮垂直居中