IE8 bug—使用max-width属性导致图片消失

bug症状:

在一些设计中给img设置max-width: 100%,以便图片能完整呈现,而不是被截掉部分。这样设置在其他浏览器下都表现完美,但唯独IE8下却出了问题。
IE8下,图片竟然不见了!

bug重现:

大家所知的一般常见的IE bug中没见过这样情况的,所以花费了一些时间来重现这个问题,max-width的设置只是导致这个现象的部分条件。
在做了一系列试验后得出了问题重现的条件。
首先给img设置max-width,但却没有明确给出width数值,并且给img标签设置width属性(不是通过css设置的width),并且img的父容器设置了浮动,IE8下查看img的width为0!表现为IE8(标准模式下)下图片消失了!

如何修复这个bug?

有三种方法:

  • 删除img标签的width属性
  • 通过css,给浮动元素明确的width值
  • 通过css,给出问题的img明确声明width:auto或max-width:none

最好的办法第三方案:通过设置CSS,给浮动元素中的没有明确设置width的img设置width:auto;或max-width: none;
来看个demo:

其中有三个logo。在IE8下,第一个logo将消失;第二个通过CSS给img设置了width:auto;第三个在img标签上没有设置width属性。
一个神奇的bug!!!!

文章翻译自Using max-width on images can make them disappear in IE8


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值