bug 查找 (一) 快速记录 IE8 下三个问题

昨天 pc 端网站上灰度,发现多个在 IE8 下的问题,描述和解决方案如下:

第一个问题是 css 文件过大

现象

把项目所有的 css 打包成单个文件,在现代的浏览器下是没有问题的,在 IE11 下的 IE8 模式也是没有问题。 但是在真实的 IE8 下,发现某个页面的 css 不能生效,百思不得其解。

然后,几个人在代码层面逐步排查问题,排查方法是:写一个 body 样式,放在不同的位置去试试,看看是否生效,同时把不能原来不生效的 css 全部注释掉。

已过几轮的调整,发现在主文件 index.css 引入新模块之后,再之后引入的 css 都不能起做用。为了验证,把新模块注释又可以使用,又把老的注掉新的模块也能使用。猜测 ie8css 的大小是有限制的。

解决方案

将新的模块单独打包成一个文件,同 index.css 一起引入页面,解决该问题。

搜了一下网上,老外也有这个问题:目前不大清楚是 file size 引起的,还是 css selector 引起的。我觉得应该是 css selector 引起的,因为 file size 会被 gzip 压缩。改天实验一下。另外发现这个问题 ie9 也有。

链接

  1. ie8-9-maximum-bytes-for-css-file

相邻兄弟选择器不能重绘的问题

现象

相邻兄弟选择器控制,也就是 +,来控制某个元素的显示,在 ie8 下不能生效。

解决方案

借鉴网上的思路,让浏览器强制重绘。方案是,在需要重绘的地方,在 body 元素,增加一个 css class,然后移除该 css class ,就达到这个目的。这个 css class 应该是没有任何效果的。

$('body').addClass('ietest');
$('body').removeClass('ietest');

链接:

  1. CSS 相邻兄弟选择器

伪类不能重绘的问题

现象

使用伪类 ::before ,发现不起作用。

解决方案

改变伪类的 content 的内容,改成 . 空格(容易被打包工具给处理掉)之类的来解决。

content: '.';
content: ' ';

总结

打包和压缩问题

打包要保证打包行为的一致性。就是说在测试环境打出来的包和生产环境打出来的包行为要一致。碰到好几次问题就是在两个环境大包出来的不一样。这里调试碰到的问题是空格在生产环境中被压缩成空字符串了。

不要使用 IE11 下的 IE8 模式进行验证

做过 IE 下兼容性问题的人都应该知道,在 IE11 开发者工具下面有个 IE8 的兼容模式,这很方便,一般情况下也够用。但是对前面所说的第一个问题(css 的大小问题),在这种兼容模式下是没有办法重现的。因此真的兼容 IE8 的话,还是要用真实的 IE8 环境来验证一下吧,模拟环境不可靠。

控制 css 的大小

对于 css 的大小的问题以后应该做模块化处理。相关页面请加载自己的 css 和基础的 css 。其他不相关的 css 不应该放在一起。这是对打包工具的要求。采用这种方案就能很好的解决 css 大小的问题。

希望不要去兼容 IE8

最根本的解决方案是,不去兼容 IE8 了。显然这是不可能的,因为网站流量中有一部分还是用的 IE8 ,没有到忽略不计的程度,IE8 还是逃不掉的。

最后

希望我说的对你有用,谢谢。

快速记录 IE8 下三个问题的更多相关文章

  1. # bug 查找 (一) 快速记录 IE8 下三个问题

    bug 查找 (一) 快速记录 IE8 下三个问题 昨天 pc 端网站上灰度,发现多个在 IE8 下的问题,描述和解决方案如下: 第一个问题是 css 文件过大 现象 把项目所有的 css 打包成单个 ...

  2. IE8下JQuery clone 出的select元素使用append添加option异常解决记录

    遇到一个怪现象,由于配置参数是多实例的, 故采用JQuery对模板HTML代码进行clone, HTML代码中包括select标签, 在克隆之后需要对select进行添加option. 在firefo ...

  3. 解决Socket.IO在IE8下触发disconnect时间过长

    本文地址: http://www.cnblogs.com/blackmanba/p/solve-socketIO-IE8-emit-disconnect-too-long.html或者http://f ...

  4. Windows系统下三十款优秀开源软件

    Windows系统下三十款优秀开源软件 1.Firefox 官方网站:http://www.getfirefox.com/ 可替换Internet Explorer 功能特点:如果你还没有使用Fire ...

  5. ie8下jquery改变PNG的opacity出现黑边,ie6下png透明解决办法

    目前互联网对于网页效果要求越来越高,不可避免的用到PNG图片,PNG分为几种格 式,PNG8 PNG24 PNG32,其中最常用的,也是显示效果和大小比较适中的则是PNG24,支持半透明,透明,颜色也 ...

  6. IE8下兼容rgba颜色的半透明背景

    在工作中做一个图片半透明遮罩时发现在IE8下不兼容 一查再知道IE8不支持rgba颜色,再搜搜兼容性方法,没想到这么快就解决了. 先说说rgba的含义: r代表red,g代表green,b代表blue ...

  7. ajax请求在ie8下缓存问题

    我今天在改项目bug的时候,发现ajax请求在ie8下有缓存,在缓存过期之前,针对相同地址发起的多个Ajax请求,只有第一次会真正发送到服务端.在某些情况下,这种默认的缓存机制并不是我们希望的(比如获 ...

  8. 记录Linux下安装elasticSearch时遇到的一些错误

    记录Linux下安装elasticSearch时遇到的一些错误 http://blog.sina.com.cn/s/blog_c90ce4e001032f7w.html (2016-11-02 22: ...

  9. 使用 CodeIgniter 框架快速开发 PHP 应用(三)

    原文:使用 CodeIgniter 框架快速开发 PHP 应用(三) 分析网站结构既然我们已经安装 CI ,我们开始了解它如何工作.读者已经知道 CI 实现了MVC式样. 通过对目录和文件的内容进行分 ...

随机推荐

  1. UVa 11631 - Dark roads

    题目大意:政府为了减小开支决定关闭一些路灯,同时保证照亮的路能连接所有路口. 又是一个MST问题,Kruskal算法,不过数据规模比较大,又Submission Error了...扔这吧... #in ...

  2. CentOS 7修复MBR和GRUB

    (转载) 一.修复MBR: MBR(Master Boot Record主引导记录): 硬盘的0柱面.0磁头.1扇区称为主引导扇区.其中446Byte是bootloader,64Byte为Partit ...

  3. ASP.NET常用的控件怎么添加

    http://jingyan.baidu.com/article/d8072ac4224747ec95cefda2.html

  4. 330. Patching Array

    Given a sorted positive integer array nums and an integer n, add/patch elements to the array such th ...

  5. MindManager 安装注册

    正版现在998元,对于个人用户来说是不是太贵了.直接下载的还不能打开,挺奇怪.

  6. sqlite3命令行

    1.查看版本信息 sqlite3 -verion 2.创建/打开数据库 sqlite3 数据库名 例:sqlite3 test.db 如果test.db不存在就创建 如果存在,则打开3.退出 .q/. ...

  7. iOS 准备

    iOS 编程知识点 iOS 基础知识点 iOS 之 系统机制 Xcode 使用技巧 Mac 使用技巧 iOS 之 英语 iOS 之 编外知识点 iOS 知识库链接

  8. Jqgrid学习(转载)

    jqGrid API 全   JQGrid是一个在jquery基础上做的一个表格控件,以ajax的方式和服务器端通信. JQGrid Demo 是一个在线的演示项目.在这里,可以知道jqgrid可以做 ...

  9. 一个好的函数(gcd)求最小公约数

    这个函数是我无意中看到的很不错,很给力,我喜欢 是用于求最小公约数的 简单的描述就是,记gcd(a,b)表示非负整数a,b的最大公因数,那么:gcd(a,b)=gcd(b,a%b)或者gcd(a,0) ...

  10. 把记事本文件固定在Win8的开始屏幕

    1.创建该文件的桌面快捷方式: 2.将快捷方式拷贝至开始菜单目录,在开始屏幕的查看全部中可以看见该文件快捷: 3.在查看全部中右键点击该快捷,选择固定在开始屏幕: