在网页设计中,为什么div+css布局的网页在ie6没问题,而在firefox却是严重错位,什么原因造成的?这是因为不同的浏览器,比如当前流行的Internet Explorer 6,Internet Explorer 7,Mozilla Firefox等,对CSS渲染不同,因此会导致同样的网页,在不同的浏览器中生成的页面效果不一样。相比IE和FF,IE容错性超级强,也就是说,即使代码写错了、少写了,也有可能显示正确,而FF在这方面要求就很严格,代码写错,CSS渲染的页面,就会严重错位。
  我们为了兼容各浏览器,而使用的特别的css定义技巧,我们称之为CSS hack,在用CSS Hack时,要注意CSS优先级,另外要注意书写的顺序:firefox的写在前面,IE7的写在中间,IE6的写在最后
  区别IE6与FF:
  background:orange;*background:blue;
  区别IE6与IE7:
  background:green !important;background:blue;
  区别IE7与FF:
  background:orange; *background:green;
  区别FF,IE7,IE6:
  background:orange;*background:green !important;*background:blue;
  IE7,IE8兼容:
  <meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7" />
1. 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]-->
2. CSS中几种浏览器对不同关键字的支持,可进行浏览器兼容性重复定义
  !important 可被FireFox和IE7识别
  * 可被IE6、IE7识别
  _ 可被IE6识别
  *+ 可被IE7识别
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中设置HTML标签的Style属性时,所有位置、宽高和尺寸值必须后跟px,IE也支持此写法,因此统一加px单位。如 Obj.Style.Height = imgObj.Style.Height + ‘px';
5. FireFox无法解析简写的padding属性设置,如padding 5px 4px 3px 1px;必须改为 padding-top:5px; padding-right:4px; padding-bottom:3px; padding-left:1px0;
6. 鼠标手势问题:FireFox的cursor属性不支持hand,但是支持pointer,IE两个都支持;所以为了兼容都用pointer
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: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;
10. 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;
11. 对超链接的CSS样式设置最好遵从这样的顺序:L-V-H-A。即
  <style type="text/css">
  <!--
  a:link {}
  a:visited {}
  a:hover {}
  a:active {}
  -->
  </style>
  这样可以避免一些访问过后的超链接就不具备hover和active样式了
12. 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.length);
  }
  strTemp+=" "+strContent;
  obj.innerHTML=strTemp;
  }
  if(document.getElementById && !document.all) toBreakWord("div_id", 37);
  /* ]]> */
  </script>
13. IE支持CSS方法cursor:url()自定义光标样式文件和滚动条颜色风格;FireFox对以上两者均不支持
14. IE有Select控件永远处于最上层的bug,且所有CSS对Select控件都不起作用
15. IE支持Form中的Label标签,包括图片和文字内容;FireFox不支持包含图片的Label,点击图片不能让标记 label for 的Radio或CheckBox产生效果
16. 形如如下格式
  <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>
17. IE和FireFox对字体small的尺寸解释不同,FireFox为13px,IE中为16px
18. IE和FireFox对空格的尺寸解释不同,FireFox为4px,IE中为8px
  首先,关于CSS hack的方法网上有很多介绍,种类繁多,初学者常常感到很困惑。这类的CSS hack的方法,有的是针对某一个非常特殊的情况的方法,有的则是相对于比较通用的一些方法。
  对于后者我们在平常的学习工作中,可以多留心收集一些,前者则不需要太关注,只是遇到的时候到网上搜索一下,寻找解决方法即可。
  这里举一个比较通用的hack方法,比如对于CSS中的某一个属性,我们希望针对不同的浏览器,设置不同的值。例如,某一个div,我们希望在Firefox中宽度为50像素,在IE中宽度为60像素。那么怎么实现呢?请看如下代码:
  #demo div{
  width:50px; /* FireFox 有效 */
  +width:60px; /* IE 有效 */
  }
  在上面的代码中, 第2行的width:50px这是普通的样式,下一行中,在width属性前面加一个加号,这条样式在Firefox中被认为无效,但是在IE中这个加号 会被忽略掉,因此仍然被理解为width属性,从而覆盖上一条的设置,这样就可以区分Firefox浏览器和IE浏览器了。
  那么如果希望进一步区分IE 6和IE 7呢?请看如下代码:
  #demo div{
  width:50px; /* FireFox 有效 */
  +width:60px; /* IE 7 有效 */
  _width:70px; /* IE 6 有效 */
  }
  上面代码就可以实现对三种浏览器的区分了。在IE7中,属性前加一个加号,这个加号会被忽略,而如果在属性前加一个下划线这整条样式会被忽略,从而实现了对这三种主流浏览器的区分。
19. FireFox对Div设置margin-left, margin-right为auto时已经居中, IE中不行
20. FireFox对Body设置text-align时, Div需要设置margin: auto(主要是margin-left margin-right) 方可居中
21. FireFox中的TextArea不支持onScroll事件
22. FireFox不支持display的inline和block
23. 在子容器加了浮动属性后,该容器将不能自动撑开
  解决方法:在标签结束后下一个标签中加上一个清除浮动的CSS clear:both;
24. 浮动后IE6解释外边距为实际边距的双倍
  解决办法:加上display:inline
25. IE6下图片下方会有空隙
  解决办法:为img加上display:block或设置vertical-align 属性为vertical-align:top | bottom |middle |text-bottom
26. IE6下两个层中间有空隙
  解决办法:设置右侧div也同样浮动float:left或者相对IE6定义 margin-right:-3px;
27. 如果用了float来布局DIV,那么就要在适当的地方清除浮动,即定义.clear{ clear:both; height:1px; top:-1px; overflow:hidden},在需要清除浮动后面都加上<div><div>。
28. LI中内容超过长度后以省略号的显示方法
  <style type="text/css">
  <!--
  li {
  width:200px;
  white-space:nowrap;
  text-overflow:ellipsis;
  -o-text-overflow:ellipsis;
  overflow: hidden;
  }
  -->
  </style>
29. 将元素的高度和行高设为相同值,即可垂直居中文本
  <style type="text/css">
  <!--
  div {
  height:30px;
  line-height:30px;
  }
  -->
  </style>
30. 对齐文本与文本输入框,须在CSS中增加vertical-align:middle;属性设置
  <style type="text/css">
  <!--
  … …
  vertical-align:middle;
  }
  -->
  </style>
31. 支持WEB标准的浏览器设置了固定高度值就不会像IE6那样被撑开,但是又想设置固定高度又想能够被撑开呢?解决办法是去掉height属性而设置min-height,为了兼容不支持min-height的IE6可以这样定义:
  {
  height:auto!important;
  height:200px;
  min-height:200px;
  }
32. 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>
33. IE6由于默认行高问题无法定义1px左右高度的容器,
  解决办法:在CSS中对容器设置如:overflow:hidden | zoom:0.08 | line-height:1px
34. 给Flash设置透明属性可使层显示在Flash之上
  <param name="wmode" value="transparent" /> <!-- 解决IE上的问题 //>
  <embed wmode="transparent" …… > <!-- 解决FireFox上的问题 //>
35. FireFox设置Padding属性后会相应的增加Width和Height属性值,IE不会
  解决办法:用!important方法多定义一套Height和Width
36. FireFox对div与div之间的空格是忽略的,但IE是处理的;因此尽量在两个相连的div之间不要有空格和回车,否则可能会造成不同浏览器之间格式不正确,比如著名的3px偏差;而且原因很难查明。
  由此可见,由于不同浏览器对代码的渲染效果不同,因此我们在制作网页时,就利用不同浏览器对不同关键字的支持,用CSS hack重复定义不同浏览器的CSS属性,实现兼容几种浏览器的网页。用CSS hack可以对任何属性使用加号或者下划线方法,来实现针对不同浏览器的各自设置。当然,使用CSS hack时要慎重,要使用符合W3C标准的CSS来进行网页设计,保证代码的可读、易维护。



© 活着的博客 - 李权辉的个人博客:人,终究是生活在现实之中,是为了活着而生活.