如何解决IE6 img与元素边界有空隙问题

很多人在在web开发中,经常会遇到图片和临界元素之间有间隔,多发生在ie6下!

如以下两种情况1.未加效果在ie6下会出现这种情况!;2、加了display:block处理后的效果;

1、代码如下:

Html代码 复制代码 运行
  1. <style type="text/css">  
  2. div{width:205px;height:121px;border:1px solid #ddd;padding:5px;}   
  3. img{width:205px;height:121px;}   
  4. </style>  
  5. <div><IMG src="http://www.ok22.org/images/TT.jpg"></div>  
  6. <div><IMG src="http://www.ok22.org/images/TT.jpg"></div>  
  7. <div><IMG src="http://www.ok22.org/images/TT.jpg"></div>  
	<style type="text/css">
	div{width:205px;height:121px;border:1px solid #ddd;padding:5px;}
	img{width:205px;height:121px;}
	</style>
	<div></div>
	<div></div>
	<div></div>

2、代码如下:

Html代码 复制代码 运行
  1. <style type="text/css">  
  2. div{width:205px;height:121px;border:1px solid #ddd;padding:5px;}   
  3. img{width:205px;height:121px;display:block;}   
  4. </style>  
  5. <div><IMG src="http://www.ok22.org/images/TT.jpg"></div>  
  6. <div><IMG src="http://www.ok22.org/images/TT.jpg"></div>  
  7. <div><IMG src="http://www.ok22.org/images/TT.jpg"></div>  
	<style type="text/css">
	div{width:205px;height:121px;border:1px solid #ddd;padding:5px;}
	img{width:205px;height:121px;display:block;}
	</style>
	<div></div>
	<div></div>
	<div></div>

这时候应先检查排版,如果仍然不能解决,可考虑以下方法:

第一,给图片img标签display:block。
img{display:block}
 
第二,定义容器里的字体大小为0。

div {
width:110px;
border:1px solid #000000;
font-size:0
}

第三,定义图片img标签vertical-align:bottom,vertical-align:middle,vertical-align:top。

img{vertical-align:bottom}

其他还有把图片下边距设为负值和改写HTML标签的排列。我觉得前三种就完全可以解决了。

造成图片在IE下与容器下边界有空隙的

在网上搜了一下,发现old9说的

图片文字等inline元素默认是和父级元素的baseline对齐的,而baseline又和父级底边有一定距离(这个距离和 font-size,font-family 相关,不一定是 5px),所以设置 vertical-align:top/bottom/text-top/text-bottom 都可以避免这种情况出现。而且不光li,其他的block元素中包含img也会有这个现象。

至于这里的HTML属性align="center"(对于图片浏览器会处理成align="middle"),就相当于vertical-align:middle; 所以道理也是一样的,只要vertical-align不取baseline,这个空隙就消失了

相关评论

1.ie的显示有几种模式,在html文档的开始部分声明
如果声明为strict模式,ie以w3c的方式显示文档,而w3c的标准里面默认是一个inline的标签,除非自己显式的声明为 block

2.那个空隙是ie针对盒模型默认的line-height和font-size. 给img desplay:block;虽然能解决问题,但没从结构上来考虑.可谓治标不治本.

转自:http://www.ok22.org/art_detail.aspx?id=173

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值