笔记:html常见的兼容问题

IE:


IE的双边距bug:

块级元素float后设置横向的margin,IE6显示的margin比较大。

解决办法:display:inline

双边距bug:在IE6下,如果对元素设置浮动,同时又设置了margin-left或margin-right,margin值会加倍

#box{ float:left; width:10px; margin:0 0 0 10px;} 
这种情况之下IE会产生20px的距离
解决方案:在float的标签样式控制中加入 _display:inline; 将其转化为行内属性。( _ 这个符号只有ie6会识别)

 IE6 不支持 PNG 透明背景,对PNG格式的图片不友好

解决办法: IE6 下使用 gif 图片

或采用下述PNG兼容IE6解决方法

IE5-8 不支持 opacity
解决办法:
.opacity {
opacity: 0.4
filter: alpha(opacity=60); /* for IE5-7 */
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=60)"; /* for IE
8*/
}

IE6默认的行高造成没有办法定义1px左右的宽度容器

解决方法:

{
    overflow:hidden;
    zoom:0.08;
    line-height:1px;
}
 

谷歌


默认会将小于12px的文本设置按照12px显示

解决方法:统一通过getAttribute()获取自定义属性

浏览器


 浏览器默认的margin和padding不同

解决方案:加一个全局的 *{margin:0;padding:0;} 来统一。
超链接访问过后 hover 样式就不出现了,被点击访问过的超链接样式不在具有 hover 和 active 了
解决方法:改变CSS属性的排列顺序 L-V-H-A
1 a:link {}
2 a:visited {}
3 a:hover {}
4 a:active {}
上下margin重合问题:
ie和ff都存在,相邻的两个div的margin-left和margin-right不会重合,但是margin-top和margin-bottom却会发生重合。
解决方法:养成良好的代码编写习惯,同时采用margin-top或者同时采用margin-bottom。
 
IE下,可以使用获取常规属性的方法来获取自定义属性,也可以使用 getAttribute() 获取自定义属性;Firefox下,只能使用getAttribute()获取自定义属性
解决方法:统一通过getAttribute()获取自定义属性
IE下,event对象有 x、y 属性,但是没有 pageX、pageY属性; Firefox下,event对象有 pageX、pageY 属性,但是没有 x、y 属性
解决方法:(条件注释)缺点是在IE浏览器下可能会增加额外的HTTP请求数。
怪异模式问题

漏写 DTD 声明,Firefox 仍然会按照标准模式来解析网页,但在 IE 中会触发怪异模式。
为避免怪异模式给我们带来不必要的麻烦,最好养成书写 DTD 声明的好习惯。
现在可以使用[html5](http://www.w3.org/TR/html5/single-page.html) 推荐的写法:
<!DOCTYPE html>

猜你喜欢

转载自www.cnblogs.com/amcy/p/9784265.html