vertical-align使图片垂直居中的小细节

对于大小未知的图片如何垂直居中是大家经常会遇到的问题.
方法 : 可以设置父元素的行高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;
            }

这里写图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值