div+css排版图片IMG下边界有空隙

做页面div+css排版的时候经常会遇到li包含img时,图片文件的下边缘出现大概5个或10个像素的间隙,找了很多办法都去不掉,遇到这样的情况,没办法只能想绕道走了。要么把图片当成背景来用,给相应的容器限制宽高,还有把图片下边距设为负值活改写HTML标签的排列,虽然效果看起来一样,但总是感觉不对劲,这不是正规的办法。

最近抽空找了资料研究了下这个问题,大概就以下原因和解决办法:

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

看了以上的,我们大概明白了,html会把图片默认为内联级元素和文字是一样的,那文字的话,给他设置不同的文字大小或字体,肯定会有不同的行高,或者它们会有默认的行高。这样就有了img下面的空隙。知道了以上的原因,那么解决办法就是这样:

第一,给图片img标签display:block。

  1. img{display:block}  

第二,定义容器里的字体大小为0。

  1. div {    
  2. width:110px;    
  3. border:1px solid #000000;    
  4. font-size:0    
  5. }  

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

  1. img{vertical-align:bottombottom}  

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

相关说明

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

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


出处:http://www.wondye.com/divcss%E6%8E%92%E7%89%88%E5%9B%BE%E7%89%87img%E4%B8%8B%E8%BE%B9%E7%95%8C%E6%9C%89%E7%A9%BA%E9%9A%99.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值