【转】CSS兼容性问题 CSS hack:区分IE6,IE7,IE8,Firefox

总体的来说就是:*_*+识别,IE专用的条件注释,对象的实际宽度不同,消除ul、ol等列表的缩进,透明,圆角,Select控件永远处于最上 层,居中问题text-align、margin: auto,浮动后IE6解释外边距为实际边距的双倍加上display:inline,字体大小,空格大小。

---------------

1.CSS中几种浏览器对不同关键字的支持,可进行浏览器兼容性重复定义

!important 可被FireFox和IE7识别
* 可被IE6、IE7识别
_ 可被IE6识别
*+ 可被IE7识别

2.IE专用的条件注释

Html代码 复制代码 收藏代码
  1. <linkrel="stylesheet"type="text/css"href="css.css"/>
  2. <linkrel="stylesheet"type="text/css"href="ie7.css"/>
  3. >
  4. <linkrel="stylesheet"type="text/css"href="ie.css"/>
  5. >







 

3. 几个浏览器对实际像素的解释

IE/Opera:对象的实际宽度 = (margin-left) + width + (margin-right)
Firefox/Mozilla:对象的实际宽度= (margin-left) + (border-left-width) + (padding- left) + width + (padding-right) + (border-right-width) + (margin-right)
4.鼠标手势问题:FireFox的cursor属性不支持hand,但是支持pointer,IE两个都支持;所以为了兼容都用pointer
5.FireFox中设置HTML标签的Style属性时,所有位置、宽高和尺寸值必须后跟px,IE也支持此写法,因此统一加px单位。如 Obj.Style.Height = imgObj.Style.Height + ‘px’;

6.FireFox无法解析简写的padding属性设置

如padding 5px 4px 3px 1px;必须改为 padding-top:5px; padding-right:4px; padding-bottom:3px; padding-left:1px0;
7.消除ul、ol等列表的缩进时,样式应写成:list-style:none;margin:0px;padding:0px;其中margin属性对IE有效,padding属性对FireFox有效

8.CSS控制透明:

IE:filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60); FireFox:opacity:0.6;

9.CSS控制圆角:

IE:不支持圆角;

Html代码 复制代码 收藏代码
  1. FireFox: -moz-border-radius:4px;或
  2. -moz-border-radius-topleft:4px;
  3. -moz-border-radius-topright:4px;
  4. -moz-border-radius-bottomleft:4px;
  5. -moz-border-radius- bottomright:4px;
FireFox: -moz-border-radius:4px;或
-moz-border-radius-topleft:4px;
-moz-border-radius-topright:4px;
-moz-border-radius-bottomleft:4px;
-moz-border-radius- bottomright:4px;

 

10.CSS双线凹凸边框:

Html代码 复制代码 收藏代码
  1. IE:
  2. border:2px outset;
  3. FireFox:
  4. -moz-border-top-colors: #d4d0c8 white;
  5. -moz-border-left-colors: #d4d0c8 white;
  6. -moz-border-right-colors:#404040 #808080;
  7. -moz-border-bottom-colors:#404040 #808080;
IE:
border:2px outset;
FireFox:
-moz-border-top-colors: #d4d0c8 white;
-moz-border-left-colors: #d4d0c8 white;
-moz-border-right-colors:#404040 #808080;
-moz-border-bottom-colors:#404040 #808080;


11.IE支持CSS方法cursor:url()自定义光标样式文件和滚动条颜色风格;FireFox对以上两者均不支持
12.IE有Select控件永远处于最上层的bug,且所有CSS对Select控件都不起作用
13.IE支持Form中的Label标签,包括图片和文字内容;FireFox不支持包含图片的Label,点击图片不能让标记 label for 的Radio或CheckBox产生效果
14.FireFox中的TextArea不支持onScroll事件
15.FireFox不支持display的inline和block
16.FireFox对Div设置margin-left, margin-right为auto时已经居中, IE中不行
17.FireFox对Body设置text-align时, Div需要设置margin: auto(主要是margin-left margin-right) 方可居中

18.对超链接的CSS样式设置最好遵从这样的顺序:L-V-H-A。

Html代码 复制代码 收藏代码
  1. <styletype="text/css">

  2. 这样可以避免一些访问过后的超链接就不具备hover和active样式了
    19.IE中设置长段落自动换行在CSS中设置word-wrap:break-word。

    20.在子容器加了浮动属性后,该容器将不能自动撑开

    解决方法:在标签结束后下一个标签中加上一个清除浮动的CSS clear:both;

    22.IE6下图片下方会有空隙

    解决办法:为img加上display:block或设置vertical-align 属性为vertical-align:top | bottom |middle |text-bottom

    23.IE6下两个层中间有空隙

    解决办法:设置右侧div也同样浮动float:left或者相对IE6定义 margin-right:-3px;

    24.LI中内容超过长度后以省略号的显示方法

    Html代码 复制代码 收藏代码
    1. <styletype="text/css">
    2.  

      25.将元素的高度和行高设为相同值,即可垂直居中文本

      Html代码 复制代码 收藏代码
      1. <styletype="text/css">
      2.  

        26.对齐文本与文本输入框,须在CSS中增加vertical-align:middle;属性设置

        Html代码 复制代码 收藏代码
        1. <styletype="text/css">

        2. 27.支持WEB标准的浏览器设置了固定高度值就不会像IE6那样被撑开,但是又想设置固定高度又想能够被撑开呢?解决办法是去掉height属性而设置min-height,为了兼容不支持min-height的IE6可以这样定义:

          Html代码 复制代码 收藏代码
          1. {
          2. height:auto!important;
          3. height:200px;
          4. min-height:200px;
          5. }
          {
          height:auto!important;
          height:200px;
          min-height:200px;
          }

           

          28.web标准中IE无法设置滚动条颜色

          解决办法:在CSS中对body的设置改为对html的

          Html代码 复制代码 收藏代码
          1. <styletype="text/css">
          2.  

            29.IE6由于默认行高问题无法定义1px左右高度的容器

            解决办法:在CSS中对容器设置如:overflow:hidden | zoom:0.08 | line-height:1px

            30.给Flash设置透明属性可使层显示在Flash之上

            Html代码 复制代码 收藏代码
            1. <paramname="wmode"value="transparent"/>

      你可能感兴趣的:(JS_HTML_CSS)