发表于: 2017-03-11 23:21:47

1 607


【武汉第98期】小课堂浅谈line-height与vertical-align

1.背景介绍:

随着互联网行业的发展,人们对网页的要求已经不限于传递信息,如何将网页设计的更合理,能更容易的让用户获取信息也愈发重要。而文字作为网页信息的主要载体,

它的样式对用户交互的影响十分巨大,本次小课堂将跟大家分享两个关于文字样式的标签:line-height和vertical-align。

2.知识剖析:

1.line-height基本概念

定义:行高是指文本行基线baseline之间的垂直距离;

a .1 line-height属性可赋值

设置固定长度(px,rem等固定单位)

设置数字:设置数字,此数字会与当前的字体尺寸相乘来设置行间距。

设置百分比:基于当前字体尺寸的百分比行距

注意:数字可以直接被继承,然后在计算行高,而百分比是先计算出行高,在以px继承;

2.vertical-align基本概念与应用

定义:使行内元素的基线相对于该元素所在行的基线的垂直对齐

默认值baseline:元素基线与父元素基线对齐

众所周知,vertical-align支持很多属性值;(关键字值:vertical-align等等: middle;长度值:vertical-align: 4px等等;百分比值:vertical-align: 10%...等等)

注意:vertical-align的百分比值不是相对于字体大小或者其他什么属性计算的,而是相对于line-height计算的。

3.常见问题

为什么在div内插入图片,会发现图片下面有一段空白间隙?

4.解决方案

a,图片默认是inline水平的,而vertical-align对块状水平的元素无感。因此,我们只要让图片display水平为block就可以了,我们可以直接设置display或者浮动、绝对定位等

b,直接修改line-height值

6.拓展思考

都用什么方法可以实现垂直居中?

.想要让单行文字垂直居中居中,可以使用刚刚讲到的line-height属性

使用刚刚讲到的vertical-align属性实现居中

使用盒子模型

把一些 div 的显示方式设置为表格,因此我们可以使用表格的 vertical-align property 属性。

使用flex弹性布局

设置父元素display:flex,使用align-items:center

7.参考文献

参考:<a href="http://www.zhangxinxu.com/wordpress/2015/08/css-deep-understand-vertical-align-and-line-height/">深入理解line-height与vertical-align

8.更多讨论

有没有其他的方法实现垂直居中?

鸣谢


返回列表 返回列表
评论

    分享到