欢迎来到天天文库
浏览记录
ID:17959016
大小:36.43 KB
页数:26页
时间:2018-09-11
《ie与firefox的css兼容大全》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、IE与Firefox的CSS兼容大全CSS对浏览器器的兼容性具有很高的价值,通常情况下IE和Firefox存在很大的解析差异,这里介绍一下兼容要点。php程序员站 常见兼容问题: 1.DOCTYPE影响CSS处理 2.FF:div设置margin-left,margin-right为auto时已经居中,IE不行 3.FF:body设置text-align时,div需要设置margin:auto(主要是margin-left,margin-right)方可居中phperz.com 4.FF:设置padding后,div会增加height和w
2、idth,但IE不会,故需要用!important多设一个height和width 5.FF:支持!important,IE则忽略,可用!important为FF特别设置样式phperz.com 6.div的垂直居中问题:vertical-align:middle;将行距增加到和整个DIV一样高line-height:200px;然后插入文字,就垂直居中了。缺点是要控制内容不要换行 7.cursor:pointer可以同时在IEFF中显示游标手指状,hand仅IE可以 8.FF:链接加边框和背景色,需设置display:block,同时设置
3、float:left保证不换行。参照menubar,给a和menubar设置高度是为了避免底边显示错位,若不设height,可以在menubar中插入一个空格。 9.在mozillafirefox和IE中的BOX模型解释不一致导致相差2px解决方法:div{margin:30px!important;margin:28px;} 注意这两个margin的顺序一定不能写反,据阿捷的说法!important这个属性IE不能识别,但别的浏览器可以识别。所以在IE下其实解释成这样:div{maring:30px;margin:28px} 重复定义的话按
4、照最后一个来执行,所以不可以只写margin:XXpx!important; 10.IE5和IE6的BOX解释不一致 IE5下div{width:300px;margin:010px010px;} div的宽度会被解释为300px-10px(右填充)-10px(左填充)最终div的宽度为280px,而在IE6和其他浏览器上宽度则是以300px+10px(右填充)+10px(左填充)=320px来计算的。这时我们可以做如下修改div{width:300px!important;width/**/:340px;margin:010px010px}
5、 关于这个/**/是什么我也不太明白,只知道IE5和firefox都支持但IE6不支持,如果有人理解的话,请告诉我一声,谢了!:) 11.ul标签在Mozilla中默认是有padding值的,而在IE中只有margin有值所以先定义ul{margin:0;padding:0;} 就能解决大部分问题 注意事项:www.phperz.com 1、float的div一定要闭合。php程序员站 例如:(其中floatA、floatB的属性已经设置为float:left;)<#divid="floatA">#div><#divid="floa
6、tB">#div><#divid="NOTfloatC">#div> 这里的NOTfloatC并不希望继续平移,而是希望往下排。 这段代码在IE中毫无问题,问题出在FF。原因是NOTfloatC并非float标签,必须将float标签闭合。 在<#divclass="floatB">#div><#divclass="NOTfloatC">#div> 之间加上<#divclass="clear">#div> 这个div一定要注意声明位置,一定要放在最恰当的地方,而且必须与两个具有float属性的div同级,之间不能存在嵌
7、套关系,否则会产生异常。 并且将clear这种样式定义为为如下即可:.clear{clear:both;} 此外,为了让高度能自动适应,要在wrapper里面加上overflow:hidden; 当包含float的box的时候,高度自动适应在IE下无效,这时候应该触发IE的layout私有属性(万恶的IE啊!)用zoom:1;可以做到,这样就达到了兼容。 例如某一个wrapper如下定义:.colwrapper{overflow:hidden;phperz.comzoom:1;margin:5pxauto;}phperz.com 2、ma
8、rgin加倍的问题。 设置为float的div在ie下设置的margin会加倍。这是一个ie6都存在的bug。 解决方
此文档下载收益归作者所有