zoukankan      html  css  js  c++  java
  • CSS样式IE浏览器跟火狐浏览器兼容写法

    前台样式最烦人的就是各种浏览器跟分辨率的 兼容问题

    首先需要了解各个浏览器之间样式在哪几方面容易出问题

    IE支持自定义光标文件cursor:url()
    IE支持自定义滚动条颜色风格
    IE6中的select有永远处在最上的bug,而且css对select不起作用。

    在form中,IE支持label,包括文字和图片;但是火狐不支持图片的label,
    点击图片不能让label for的radio或者checkbox产生效果。

    IE和火狐都是支持onscroll事件的,但是火狐中textarea对此事件不支持。

    CSS方面,IE中支持在CSS中嵌入expresion,而Firefox不支持
    火狐支择相邻子选择符“>”,而IE6不支持(IE7支持)

    火狐对display的inline-block不支持,而IE均支持。

    CSS对浏览器器的兼容性具有很高的价值,通常情况下IE和火狐存在很大的解析差异,这里介绍一下兼容要点。
    对高度的解析
    IE:将根据内容的高度变化,包括未定义高度的图片内容,即使定义了高度,当内容超过高度时,将使用实际高度
    火狐:没有定义高度时,如果内容中包括了图片内容,火狐的高度解析是根据印刷标准,这样就会造成和实际内容高度不符合的情况;当定义了高度,但是内容超过高度时,内容会超出定义的高度,但是区域使用的样式不会变化,造成样式错位。

    结论:大家在可以确定内容高度的情况下最好定义高度,如果真的没有办法定义高度,最好不用使用边框样式,否则样式肯定会出现混乱!

    img对象alttitle的解析
    alt:当照片不存在或者load错误时的提示;
    title:照片的tip说明。
    在IE中如果没有定义title,alt也可以作为img的tip使用,但是在火狐中,两者完全按照标准中的定义使用

    结论:大家在定义img对象时,最后将alt和title对象都写全,保证在各种浏览器中都能正常使用

    其他的细节差别
    当你在写css的时候,特别是用float: left(或right)排列一窜图片时,会发现在火狐里面正常而IE里面有问题。无论你用margin:0,还是border: 0来约束,都无济于事。

    其实这里还有另外一个问题,就是IE对于空格的处理,火狐是忽略的而IE对于块与块之间的空格是处理的。也就是说一个div结束后要紧接着一个div写,中间不要有回车或者空格。不然也许会有问题,比如3px的偏差,而且这个原因很难发现。

    非常不走运的是我又碰到了这样的问题,多个img标签连着,然后定义的float: left,希望这些图片可以连起来。但是结果在火狐里面正常而IE里面显示的每个img都相隔了3px。我把标签之间的空格都删除都没有作用。

    后来的解决方法是在img外面套li,并且对li定义margin: 0,这样就解决了IE和火狐的显示偏差。IE对于一些模型的解释会产生很多错误问题,只有多多尝试才能发现原因。

    10大兼容要点

    1、DOCTYPE 影响 CSS 处理
    2、火狐: div 设置 margin-left, margin-right 为 auto 时已经居中, IE 不行
    3、火狐: body 设置 text-align 时, div 需要设置 margin: auto(主要是 margin-left,margin-right) 方可居中
    4、火狐: 支持 !important, IE 则忽略, 可用 !important 为火狐特别设置样式,值得注意的是,一定要将xxxx !important 这句放置在另一句之上
    5、div 的垂直居中问题: vertical-align:middle; 将行距增加到和整个DIV一样高 line-height:200px; 然后插入文字,就垂直居中了。缺点是要控制内容不要换行
    6、cursor: pointer 可以同时在 IE FF 中显示游标手指状, hand 仅 IE 可以
    7、火狐: 链接加边框和背景色,需设置 display: block, 同时设置 float: left 保证不换行。参照 menubar, 给 a 和 menubar 设置高度是为了避免底边显示错位, 若不设 height, 可以在 menubar 中插入一个空格。
    8、在火狐和IE中的BOX模型解释不一致导致相差2px解决方法:div{margin:30px!important;margin:28px;}
    注意这两个margin的顺序一定不能写反,!important这个属性IE不能识别,但别的浏览器可以识别。所以在IE下其实解释成这样:div{maring:30px;margin:28px}
    重复定义的话按照最后一个来执行,所以不可以只写{margin:XXpx!important;}

    9、ul标签在火狐中默认是有padding值的,而在IE中只有margin有值所以先定义ul{margin:0;padding:0;}

    接下来就是IE6/IE7/IE8以及火狐浏览器中兼容样式的写法

    IE6:top{_100px;}此种方法只有IE6可识别 IE7/8跟火狐无法识别

    IE7:*+html top{100px;}此种方法只有IE7可识别 IE6/8跟火狐无法识别

    IE8:top{100px;}

    火狐::root body top{width}此种写法仅火狐能识别 IE 浏览器无法识别

    如果只让ff、IE8看见用html>/**/body .head{color:#000;}
    如果只是不让ie6看见用html>body .head{color:#000;} 即对IE 6无效
    如果只是不让ff、IE8看见用*body .head{color:#000;}    即对ff、IE8无效

    html*{color:#f00}            支持IE6 IE7          不支持 IE8 FF
    body>p{color:#f00}            支持IE7 IE8 FF        不支持 IE6
    html[xmlns] p {color:#f00}        支持 IE7 IE8 FF    不支持 IE6
    @import "style.css"
    @import "style.css"
    @import url(style.css)
    @import url('style.css')
    @import url("style.css")        支持 IE6 IE7 IE8 FF
    P{/*/*color:#f00;/* */}            支持 IE6 IE7  FF     不支持 IE8

  • 相关阅读:
    迭代器生成器
    elasticsearch系列(五)score
    数据结构(五)串
    数据结构系列(四)栈与队列
    数据结构系列(三)线性表
    数据结构系列(二)算法
    数据结构系列(一)入门
    elasticsearch系列(四)部署
    SpringBoot系列(一)RestTemplate
    基于python的爬虫(一)
  • 原文地址:https://www.cnblogs.com/ylsoo/p/2796156.html
Copyright © 2011-2022 走看看