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 还是逃不掉的。

最后

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

# bug 查找 (一) 快速记录 IE8 下三个问题的更多相关文章

  1. 快速记录 IE8 下三个问题

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

  2. BUG笔记:Win XP IE8下HTML Parsing Error: Unable to modify the parent container element before the child

    [Bug描述]Windows XP IE8的某些版本下页面只显示一部分,其余为空白.IE左下角有惊叹号报错标志,点开后显示字符如下: HTML Parsing Error: Unable to mod ...

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

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

  4. angular在ie8下的一个bug

    昨天拿项目在ie8下测试,发现不少bug,其中有一个bug让我很不解,报了一个thead开头的bug,因为已经切回到linux下了,我就不报具体是什么bug了,鼓捣了半天,发现引用angular的应用 ...

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

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

  6. ie8下$(document).on('mouseover mouseout','ul li',function(){})的bug

    $(document).on('mouseover mouseout','ul li',function(){ if (event.type == 'mouseover') {           c ...

  7. ueditor1.4.3 在IE8下的 BUG

    ueditor1.4.3  .net 版 在IE8 下,多图片上传完成后,点击确认时报错,无法插入图片到编辑器中 原因是 ueditor.all.js 中的 24835 行 if (whitList[ ...

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

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

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

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

随机推荐

  1. http://www.cnblogs.com/yaozhenfa/archive/2015/06/14/4574898.html

    笔者这里采用的是mongoDB官网推荐使用.net驱动: http://mongodb.github.io/mongo-csharp-driver/2.0/getting_started/quick_ ...

  2. AndroidManifest中的Intent-filter标签

    经过测试,intent-filter标签中的: 1. <action android:name="android.intent.action.MAIN" /> 代表这是 ...

  3. 并不对劲的CTS2019

    day0 没有C day1 t1:并不想简述题意 10分暴力走人 t2:有\(n\)个在\([1,D]\)内的均匀随机整数,问有多少的概率出现\(m\)对相同的 设\(f(i,j)\)表示考虑前\(i ...

  4. kafka之六:为什么Kafka那么快

    转自:  http://mp.weixin.qq.com/s?__biz=MzIxMjAzMDA1MQ==&mid=2648945468&idx=1&sn=b622788361 ...

  5. Spring中JdbcTemplate的基础用法

    Spring中JdbcTemplate的基础用法 1.在DAO中使用JdbcTemplate 一般都是在DAO类中使用JdbcTimplate,在XML配置文件中配置好后,可以在DAO中注入即可. 在 ...

  6. 1.18-1.21 Oozie Coordinator调度

    一.时区问题 1.修改系统时区 ## [root@hadoop-senior hadoop-2.5.0-cdh5.3.6]# rm -rf /etc/localtime [root@hadoop-se ...

  7. UVa 753 A Plug for UNIX (最大流)

    题意:给定 n 种插座,m种设备,和k个转换器,问你最少有几台设备不能匹配. 析:一个很裸的网络流,直接上模板就行,建立一个源点s和汇点t,源点和每个设备连一条边,每个插座和汇点连一条边,然后再连转换 ...

  8. HDU - 1016 Prime Ring Problem 经典素数环

    Prime Ring Problem A ring is compose of n circles as shown in diagram. Put natural number 1, 2, ..., ...

  9. ASP.NET中的几种弹出框提示基本方法

    NET程序的开发过程中,常常需要和用户进行信息交互,对话框的出现将解决了这些问题,下面是本人对常用对话框使用的小结,希望对大家有所帮助 我们在.NET程序的开发过程中,常常需要和用户进行信息交互,比如 ...

  10. Angular6在自定义指令中使用@HostBingDing() 和@HostListener()

    emmm,,,最近在为项目的第二阶段铺路,偶然看到directive,想想看因为项目已经高度集成了第三方组件,所以对于自定义指令方面的经验自己实在知之甚少,后面经过阅读相关资料,总结一篇关于在自定义指 ...