对于大小未知的图片如何垂直居中是大家经常会遇到的问题.
方法 : 可以设置父元素的行高line-height等于高度height,也就是说行高和高度一样,然后利用vertical-align:middle;达到垂直居中的效果,
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
*{
margin:0;
padding:0;
}
div{
width:100%;
height: 400px;
line-height: 400px;
text-align: center;
background-color: tan;
}
div img{
vertical-align: middle;
}
</style>
</head>
<body>
<div>
<img src="images/1.jpg" alt="图片" />
</div>
</body>
</html>
这段代码中1.jpg是一个200X200的图片
看上去是居中显示了 ,但是并没有,我们将div的高度设置小点看看;
div{
width:100%;
height: 210px;
line-height: 210px;
text-align: center;
background-color: tan;
}
可以看出来了 图片其实并没有居中;
为什么会出现这种情况呢?
在css权威指南中是这么说的:
vertical-align:middle这个值通常适合于图像,因为它使元素的纵向的中点对齐本行的“中间”。行的中间定义为基线以上半个ex处的那个点,而ex的值源于父元素的字体尺寸。在实际应用中,因为大多数用户代理将1ex等同于0.5em,middle将会是元素的纵向点与父元素基线以上四分之一em处的一个点对齐。
注意 要理解这里首先要清楚基线和ex的概念,基线并不是文字的下端沿.而ex则值的是小写字母’x’的高度.如图
不难看出ex与字体大小相关,而且基线上0.5ex处并不是在中线上,因为会产生之前的偏差.我们可以通过增大字体来验证这个猜想是否正确;
div{
width:100%;
height: 210px;
line-height: 210px;
font-size:80px;
text-align: center;
background-color: tan;
}
结果发生了偏差
所以解决这个问题的方法是把父级字体设置为0;
div{
width:100%;
height: 210px;
line-height: 210px;
font-size:0;
text-align: center;
background-color: tan;
}