转载请注明: TheViper http://www.cnblogs.com/TheViper部分翻译自原文:Vertical-Align: All You Need To Know(本屌英语非专业,部分意译)很多时候,我总是需要垂直对齐一行元素。之前,我一般用float ...
转载请注明: TheViper http://www.cnblogs.com/TheViper
部分翻译自原文:Vertical-Align: All You Need To Know(本屌英语非专业,部分意译)
很多时候,我总是需要垂直对齐一行元素。之前,我一般用float,有时用position: absolute,实在没办法就只有设置margin或padding。
我真的不喜欢上面那些方法。float只能让一行元素在顶部对齐,如果要垂直对齐则需要另外调整。position: absolute让元素脱离文档流,使得它们不能影响周围的元素。而设置margin或padding让css变得不优雅。
但是vertical-align让我眼前一亮,我觉得它应该得到更多的关注。从技术上讲,使用vertical-align布局是hack行为,因为它并不是为了解决这个问题而诞生的。它本来是被用来对齐文本和元素旁边的文本。尽管如此,vertical-align可以让我们在不同的上下文环境灵活的,细粒度的对齐元素,因为不需要知道元素的大小,所有元素仍然在文档流中。
使用Vertical-Align的条件
vertical-align是用来对齐行内元素的,也就是说作用于这些display属性
inline,inline-block,inline-table(本文不讨论)。
inline-block顾名思义,块级元素在行内元素里面,元素可以有width,height,border, margin,padding.
另一方面,行内元素会一个接一个排在一起,只要在当前行还有空间容纳行内元素。如果没有空间则在下面创建新的一行。这些行内元素被称作line box。
line box包含一行的所有内容,一行内的元素的大小会影响line box的高度。下面的图显示了line box的顶部和底部是怎样定义的,两个红线间表示一个line box.
基线(baseline)和外边缘(Outer Edges)
垂直对齐最重要的参考点line box涉及元素的基线,在某些情况下,元素盒子模型的顶部边缘和底部边缘是非常重要的。下图让我们直观的看到涉及元素的baseline和outer edges
红线表示行高(line-height)的顶部和底部边缘,绿线表示文字的高度(font-size),蓝线是基线。
上面左边的图line-height等于font-size,所以红线和绿线重合。中间图line-height是font-size的两倍,右边图的line-height是font-size的1/2.
行内元素的外边缘会和line-height的顶部和底部边缘对齐,上面右图中,行内元素的外边缘仍然是红线,尽管line-height比font高度小。
另外,可以看到行内元素的基线在font高度一半位置偏下。
inline-block元素
从左到右,inline-block元素里面有in-flow(没有脱离文档流)内容,inline-block元素里面有in-flow内容但overflow:hidden,inline-block元素里面有out-flow内容(内容区域有高度)。
红线表示margin的边缘,黄线是border,绿线是padding,内容是蓝**域,蓝线是baseline.
inline-block元素的外边缘是它的margin-box的顶部和底部边缘。
可以看到,inline-block元素的baseline取决于元素是否有in-flow内容。
上面左图的baseline是上一个内容元素的baseline,这个内容元素根据自身情况确定自己的baseline.
中图设置overflow属性为非visible,这时baseline是inline-block元素的margin-box的底部边缘,也就是它自己的底部边缘。
右图的baseline仍然是它的margin-box的底部边缘。
Line Box
<span class="center"> <span class="middle bg-grey">This</span> <span class="tall box bg-grey text-top"> </span> <span class="top bg-grey">can</span> <span class="tall box bg-grey text-bottom"> </span> <span class="bottom bg-grey">happen.</span></span>
原标题:(译)关于Vertical
关键词:
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们:
admin#shaoqun.com
(#换成@)。