« Server.Htmlencode的转义字符用法CSS控制DIV出现滚动条效果 »

网页浏览器关于整理浏览器对网页的兼容性问题-CSS

分类: 网页设计代码 发布: roger 浏览: 日期: 2010年8月17日

   CSS兼容性:

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

  !important 可被FireFox以及IE7识别

  * 可被IE6、IE7识别

  _ 可被IE6识别

  * 可被IE7识别

  2. IE专用的条件注解

  <!--其它浏览器 -->

  <link rel="stylesheet" type="text/css" href="css.css" />

  <!--[if IE 7]>

  <!-- 合适于IE7 -->

  <link rel="stylesheet" type="text/css" href="ie7.css" />

  <![endif]-->

  <!--[if lte IE 6]>

  <!-- 合适于IE6及一下 -->

  <link rel="stylesheet" type="text/css" href="ie.css" />

  <![endif]-->

  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(sty le=0,opacity=60); FireFox:opacity:0.6;

  9. CSS控制圆角:IE:不支持圆角;

  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双线凹凸边框: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。即

  <style type="text/css">

  <!--

  a:link {}

  a:visited {}

  a:hover {}

  a:active {}

  -->

  </style>

  如允许以制止一些访问过后的超链接就不具备hover以及active样式了

  19. IE中设置长段落自动换行在CSS中设置word-wrap:break-word;FireFox中使用JS插入的方法来实现,具体代码如次:

  <script type="text/javascript">

  /* <![CDATA[ */

  function toBreakWord(el, intLen){

  var obj=document.getElementById(el);

  var strContent=obj.innerHTML;

  var strTemp="";

  while(strContent.length>intLen){

  strTemp =strContent.substr(0,intLen) " ";

  strContent=strContent.substr(intLen,strContent.len gth);

  }

  strTemp =" " strContent;

  obj.innerHTML=strTemp;

  }

  if(document.getElementById && !document.all) toBreakWord("div_id", 37);

  /* ]]> */

  </script>

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

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

  21. 浮动后IE6诠释外边距为实际边距的双倍

  解决办法:加上display:inline

  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中内容超过长度后以省略号的显示方法

  <style type="text/css">

  <!--

  li {

  width:200px;

  white-space:nowrap;

  text-overflow:ellipsis;

  -o-text-overflow:ellipsis;

  overflow: hidden;

  }

  -->

  </style>

  25. 将元素的高度以及行高设为不异值,便可垂直居中文本

  <style type="text/css">

  <!--

  div {

  height:30px;

  line-height:30px; } --> </style> 26. 对齐文本与文本输入框,须在CSS中增长vertical-align:middle;属性设置

  <style type="text/css">

  <!--

  ……

  vertical-align:middle;

  }

  -->

  </style>

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

  {

  height:auto!important;

  height:200px;

  min-height:200px;

  }

  28. web标准中IE没有办法设置滚动条颜色

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

  <style type="text/css">

  <!--

  html {

  scrollbar-face-color:#f6f6f6;

  scrollbar-highlight-color:#fff;

  scrollbar-shadow-color:#eeeeee;

  scrollbar-3dlight-color:#eeeeee;

  scrollbar-arrow-color:#000;

  scrollbar-track-color:#fff;

  scrollbar-darkshadow-color:#fff;

  }

  -->

  </style>

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

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

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

  <param name="wmode" value="transparent" /> <!-- 解决IE上的问题 //>

  <embed wmode="transparent" …… > <!-- 解决FireFox上的问题 //>

  31. FireFox设置Padding属性后会相应的增长Width以及Height属性值,IE不会

  解决办法:用!important方法多定义一套Height以及Width

  32. FireFox对div与div之间的空格是忽略的,但IE是处理的;因此尽量在两个相连的div之间不要有空格以及回车,否则可能会造成不同浏览器之间格式不正确,好比著名的3px偏差;而且原因很难查明

  33. 形如如次格式

  <div id="parent">

  <div id="content"> </div>

  </div>

  当Content内容很长时间,即使parent设置了高度100%或auto,在不同浏览器下还是不克不及无缺的自动伸展;解决办法在层的最下方孕育发生一个高度为1的空格,代码如次

  <div id="parent">

  <div id="content"> </div>

  <div style="font: 0px/0px sans-serif;clear: both;display: block"> </div>

  </div>

  34. IE以及FireFox对字体small的尺寸诠释不同,FireFox为13px,IE中为16px

  35. IE以及FireFox对空格的尺寸诠释不同,FireFox为4px,IE中为8px 文止于此,由于作者才疏学浅,文中纰漏在所难免,接待大家批评指正、相互交流。

相关文章:

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

Powered By Z-Blog 1.8 Walle Build 91204

Copyright 2008-2022 WWW.XMHJFB.COM Rights Reserved 闽ICP备16020319号