IE8标准模式下图片max-width的bug

bug的发现

在IE9下面,打开开发者工具,切换IE8模式下,发现一些图片看不见了。本来之前也有遇到这个问题,不过没有注意,因为是自己的代码问题,今天搜索了一下,发现这个问题是一个Bug来的。

bug产生的原因

  1. 图片通过css设置了max-width:100%
  2. 图片设置了width属性,且不等于auto的值,或者css中设置了width,且不等于auto。
  3. 图片的父级元素设置了float,且没有设置宽度

如果满足以上条件,在IE8(标准模式)中,图片宽度为0,不会在浏览器中显示。

bug的解决思路

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

修改以上任意一种方法,都可以解决这个bug,建议根据具体情况来解决,IE8 css hack:.selector { property: value9; }

演示

 


关注我

我的微信公众号:前端开发博客,在后台回复以下关键字可以获取资源。

  • 回复「小抄」,领取Vue、JavaScript 和 WebComponent 小抄 PDF
  • 回复「Vue脑图」获取 Vue 相关脑图
  • 回复「思维图」获取 JavaScript 相关思维图
  • 回复「简历」获取简历制作建议
  • 回复「简历模板」获取精选的简历模板
  • 回复「加群」进入500人前端精英群
  • 回复「电子书」下载我整理的大量前端资源,含面试、Vue实战项目、CSS和JavaScript电子书等。
  • 回复「知识点」下载高清JavaScript知识点图谱

每日分享有用的前端开发知识,加我微信:caibaojian89 交流