首先,整个project分为以下一些文件夹:
Explain:IE6下如果浮动元素与非浮动元素相连,就会出现两者间隔3像素这个Bug,可以直接设置margin-left或
margin-right为负数就可以解决。如果存在haslayout属性不为true的情况,可以先激发haslayout属性再设置margin。
但这样却不能兼容chrome和firefox等主流浏览器,因为浮动会让元素偏离原来文本流,导致会影响其他元素的宽高度计算。
而float既能激发haslayout也能兼容chrome、firefox等,所以直接把非浮动元素设置为浮动就可以解决这个问题了。
Explain:IE6下如果同时满足以下条件:(1)块级元素(2)同时设置float: left、margin-left或float: right、
margin-right时,会导致margin变成原来的两倍,这时候只需要添加display: inline样式就可以解决了。至于存在设
置了display: inline后还可以设置width和height的所谓“冲突”问题,就不必纠结了,加这个样式纯粹是用来兼容IE6
而已。
Explain:IE6不支持position: fixed,可以设置*position: absolute然后再设置*top和*left就可以了。(*表示
只有IE6、7才能识别)至于为什么不通过CSS的expression来设置呢?个人认为从网页性能的角度来考虑,能CSS解决的问
题就尽量不通过脚本来解决,所以这里“逼不得已”采用了CSS Hack。
Explain:设置透明在过往一般采用CSS opacity的属性,但这种方法会使应用该样式元素的后代元素都继承这种效果,
所以现在改成用CSS3的新属性rgba来设置透明度。有开发人员通过切图的方式实现这种透明效果,个人认为不太科学,
因为图片会减慢网页的加载速度,虽说CSS Hack能不用尽量不用,但在此却很有必要。当你试把条件注释中的代码放到
原样式中,你会发现IE9下透明层更“透明”了,但IE10下却不会,为什么呢?因为IE9同时支持自身alpha滤镜和CSS3
的rgba,就等同“两次透明”了,而IE10已经不支持alpha了,但IE6、7、8却不支持rgba,只支持自身的alpha,所以
可以通过这种方式实现这种效果。
Explain:在以下情况会产生文字溢出bug:
(1)一个容器里包含2个具有“float”样式的容器
(2)第二个容器的宽度大于父容器的宽度或父容器与第二个容器宽度之差小于3
(3)在第二个容器前存在注释
PS:溢出文字的字数 = 注释条数 * 2 -1,必须同时满足以上三个条件才会出现这个bug
解决方法有很多种,以下我逐个分析:
(1)改变结构,不出现具有两个“float”样式的容器————这方法因噎废食,如果页面要求必须设定该样式就办不到了
(2)减少第二个容器的宽度————这在页面布局允许的情况下可以办到,但布局复杂时比较困难
(3)去掉所有注释————显然,这是十分不理智的做法
(4)改变注释的位置————显然,这是一种很优秀的写法
(5)在第二个容器后面加一个或多个块来解决————的确可以解决,可是影响网页效率
显然,我们应该采取方法(4)