快速记录 IE8 下三个问题
bug 查找 (一) 快速记录 IE8 下三个问题
昨天 pc
端网站上灰度,发现多个在 IE8
下的问题,描述和解决方案如下:
第一个问题是 css 文件过大
现象
把项目所有的 css
打包成单个文件,在现代的浏览器下是没有问题的,在 IE11
下的 IE8
模式也是没有问题。 但是在真实的 IE8
下,发现某个页面的 css
不能生效,百思不得其解。
然后,几个人在代码层面逐步排查问题,排查方法是:写一个 body
样式,放在不同的位置去试试,看看是否生效,同时把不能原来不生效的 css 全部注释掉。
已过几轮的调整,发现在主文件 index.css
引入新模块之后,再之后引入的 css
都不能起做用。为了验证,把新模块注释又可以使用,又把老的注掉新的模块也能使用。猜测 ie8
对 css
的大小是有限制的。
解决方案
将新的模块单独打包成一个文件,同 index.css
一起引入页面,解决该问题。
搜了一下网上,老外也有这个问题:目前不大清楚是 file size
引起的,还是 css selector
引起的。我觉得应该是 css selector
引起的,因为 file size
会被 gzip
压缩。改天实验一下。另外发现这个问题 ie9
也有。
链接
相邻兄弟选择器不能重绘的问题
现象
相邻兄弟选择器控制,也就是 +
,来控制某个元素的显示,在 ie8
下不能生效。
解决方案
借鉴网上的思路,让浏览器强制重绘。方案是,在需要重绘的地方,在 body
元素,增加一个 css class
,然后移除该 css class
,就达到这个目的。这个 css class
应该是没有任何效果的。
$('body').addClass('ietest');
$('body').removeClass('ietest');
链接:
伪类不能重绘的问题
现象
使用伪类 ::before
,发现不起作用。
解决方案
改变伪类的 content
的内容,改成 . 空格
(容易被打包工具给处理掉)之类的来解决。
content: '.';
content: ' ';
总结
打包和压缩问题
打包要保证打包行为的一致性。就是说在测试环境打出来的包和生产环境打出来的包行为要一致。碰到好几次问题就是在两个环境大包出来的不一样。这里调试碰到的问题是空格在生产环境中被压缩成空字符串了。
不要使用 IE11
下的 IE8
模式进行验证
做过 IE
下兼容性问题的人都应该知道,在 IE11
开发者工具下面有个 IE8
的兼容模式,这很方便,一般情况下也够用。但是对前面所说的第一个问题(css
的大小问题),在这种兼容模式下是没有办法重现的。因此真的兼容 IE8
的话,还是要用真实的 IE8
环境来验证一下吧,模拟环境不可靠。
控制 css
的大小
对于 css
的大小的问题以后应该做模块化处理。相关页面请加载自己的 css
和基础的 css
。其他不相关的 css
不应该放在一起。这是对打包工具的要求。采用这种方案就能很好的解决 css
大小的问题。
希望不要去兼容 IE8
最根本的解决方案是,不去兼容 IE8
了。显然这是不可能的,因为网站流量中有一部分还是用的 IE8
,没有到忽略不计的程度,IE8
还是逃不掉的。
最后
希望我说的对你有用,谢谢。
快速记录 IE8 下三个问题的更多相关文章
- # bug 查找 (一) 快速记录 IE8 下三个问题
bug 查找 (一) 快速记录 IE8 下三个问题 昨天 pc 端网站上灰度,发现多个在 IE8 下的问题,描述和解决方案如下: 第一个问题是 css 文件过大 现象 把项目所有的 css 打包成单个 ...
- IE8下JQuery clone 出的select元素使用append添加option异常解决记录
遇到一个怪现象,由于配置参数是多实例的, 故采用JQuery对模板HTML代码进行clone, HTML代码中包括select标签, 在克隆之后需要对select进行添加option. 在firefo ...
- 解决Socket.IO在IE8下触发disconnect时间过长
本文地址: http://www.cnblogs.com/blackmanba/p/solve-socketIO-IE8-emit-disconnect-too-long.html或者http://f ...
- Windows系统下三十款优秀开源软件
Windows系统下三十款优秀开源软件 1.Firefox 官方网站:http://www.getfirefox.com/ 可替换Internet Explorer 功能特点:如果你还没有使用Fire ...
- ie8下jquery改变PNG的opacity出现黑边,ie6下png透明解决办法
目前互联网对于网页效果要求越来越高,不可避免的用到PNG图片,PNG分为几种格 式,PNG8 PNG24 PNG32,其中最常用的,也是显示效果和大小比较适中的则是PNG24,支持半透明,透明,颜色也 ...
- IE8下兼容rgba颜色的半透明背景
在工作中做一个图片半透明遮罩时发现在IE8下不兼容 一查再知道IE8不支持rgba颜色,再搜搜兼容性方法,没想到这么快就解决了. 先说说rgba的含义: r代表red,g代表green,b代表blue ...
- ajax请求在ie8下缓存问题
我今天在改项目bug的时候,发现ajax请求在ie8下有缓存,在缓存过期之前,针对相同地址发起的多个Ajax请求,只有第一次会真正发送到服务端.在某些情况下,这种默认的缓存机制并不是我们希望的(比如获 ...
- 记录Linux下安装elasticSearch时遇到的一些错误
记录Linux下安装elasticSearch时遇到的一些错误 http://blog.sina.com.cn/s/blog_c90ce4e001032f7w.html (2016-11-02 22: ...
- 使用 CodeIgniter 框架快速开发 PHP 应用(三)
原文:使用 CodeIgniter 框架快速开发 PHP 应用(三) 分析网站结构既然我们已经安装 CI ,我们开始了解它如何工作.读者已经知道 CI 实现了MVC式样. 通过对目录和文件的内容进行分 ...
随机推荐
- JAVA8 HashMap 新特性
1. 链表解决冲突的方式: java中处理Hash散列后的冲突使用的是链表法: java8之前只是使用的简单Entry链表存储键值对.java8后,在Entry队列的长度大于8之后,会自动 ...
- Cookie 简单使用记录浏览记录
ItemsDAO.java package dao; import java.util.* ; import java.sql.* ; import util.DBHelper; import ent ...
- Linux环境下的GCC编译器与GDB调试工具介绍
假如现在我们有如下代码需要编译运行和调试.文件名为:test.c #include <stdio.h> int main() { int day, month, year, sum, le ...
- Linux释放内存脚本
vi recover_mem.sh #!/bin/bash ################## #author:rrhelei@126.com# ################## #系统分配的 ...
- Mac 电脑系统的重装
首先来说一下我为什么会想到重装Mac的系统呢??? 其实呢 很简单的一个理由,在我写上一个项目的时候,在功能code编写完成后,在模拟器上运行是完全没有问题的,但是在真机上就不行,大家也都知道,在X ...
- 如何给js动态创建的dom添加事件
delegate() 方法 实例 当点击鼠标时,隐藏或显示 p 元素: $("div").delegate("button","click" ...
- 移动设备应用程序中支持多个屏幕大小和 DPI 值
支持多个屏幕大小和 DPI 值的指导原则 要部署独立于平台的应用程序,应了解不同的输出设备.设备可以具有不同的屏幕大小或分辨率以及不同的 DPI 值或密度. Flex 工程师 Jason SJ 在他的 ...
- java算法 蓝桥杯 扶老奶奶街
一共有5个红领巾,编号分别为A.B.C.D.E,老奶奶被他们其中一个扶过了马路. 五个红领巾各自说话: A :我和E都没有扶老奶奶 B :老奶奶是被C和E其中一个扶过大街的 C :老奶奶是被我和D其中 ...
- 如何:使用 Visual Basic 编写基于 Unity3D 的计算器
随着 .NET 全平台战略的推进,微软正在让以 C# 为先锋的 .NET 拥有跨平台特性.这个过程中一直有人想知道其它 .NET 语言对跨平台的支持有什么改进,熟悉 C# 但是喜欢用 VB 的我也不例 ...
- 真分布式SolrCloud+Zookeeper+tomcat搭建、索引Mysql数据库、IK中文分词器配置以及web项目中solr的应用(1)
版权声明:本文为博主原创文章,转载请注明本文地址.http://www.cnblogs.com/o0Iris0o/p/5813856.html 内容介绍: 真分布式SolrCloud+Zookeepe ...