盒子含图片多出几像素高度的问题

本文探讨了在HTML中,当盒子包含图片时,盒子高度为何会比图片高度多出几像素的问题。该现象在不同HTML标准中普遍存在。解决方案包括设置img标签属性、调整父元素样式或改变图片元素的display属性。问题的根本原因是img元素下方的空白间距。

问题

当一个盒子中含有一张图片,即使这个盒子(不管是块级元素还是行内块)没有设置高度,也会被内容撑起来等于图片的高度,但是事实并非如此。盒子的高度不等于图片的高度,而是多出了几像素,而这种问题出现在,html5、xhtml1.0 strict、xhtml1.1、html4.01 strict中。

代码

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style type="text/css">
		.box1{		
			background-color:pink;
		}
		
	</style>
</head>
<body>
	<div class="box1">
		<img src="../images/3.jpg" alt="">
	</div>	
</body>
</html>

展示

在这里插入图片描述

解决方法

1、img标签添加属性

img{
	vertical-align: top;
}

2、img的父标签添加

font-size:0;

3、img是inline-block元素转成block元素

img{
	display:block;
}

当然还有给父元素设置行高为0也可以解决。

产生原因

img下几像素空白产生原因

为什么图片下面总是会多出3-5像素

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值