日期:2014-05-17  浏览次数:20595 次

css注意问题(浏览器兼容)
CSS HACK(css兼容):什么是浏览器HACK:当我们使用不同的浏览器(Firefox IE7 IE6)访问同一个网站,或者页面的时候,会出现一些不兼容的问题,有的显示出来正常,有的显示出来不正常,我们在编写CSS的时候会很恼火,刚修复了这个浏览器的问题,结果另外一个浏览器却出了新问题。而HACK就是一种办法,能让你在一个CSS里面独立的写支持不同浏览器的样式。这下就和谐了。呵呵!



程序代码
第一个兼容,IE FF 所有浏览器 公用(其实也不算是兼容)
height:100px;
第二个兼容 IE6专用
_height:100px;
第三个兼容 IE6 IE7公用
*height:100px;
介绍完了这三个兼容了,下面我们再来看看如何在一个样式里分别给一个属性定义IE6 IE7 FF专用的兼容,看下面的代码,顺序不能错哦:
程序代码
height:100px;
*height:120px;
_height:150px;
下面我简单解释一下各浏览器怎样理解这三个属性:
在FF下,第2、3个属性FF不认识,所以它读的是 height:100px;
在IE7下,第三个属性IE7不认识,所以它读第1、2个属性,又因为第二个属性覆盖了第一个属性,所以IE7最终读出的是第2个属性 *height:120px;
在IE6下,三个属性IE6都认识,所以三个属性都可以读取,又因为第三个属性覆盖掉前2个属性,所以IE6最终读取的是第三个属性。
IE7、FF 共用
height: 100px !important(优先级);




再比如:
#bgcolor { background:red !important; /* Firefox 等其他浏览器 */ background:blue; /* IE6 */}*+html #bgcolor { background:green !important; /* IE7 */}
id="bgcolor" 的控件要在 IE6 中显示蓝色, IE7 中显示绿色, Firefox 等其他浏览器中显示红色.

IE6 不认 !important, 也不认 *+html. 所以 IE6 只能是 blue.
IE7 认 !important, 也认 *+html, 优先度: (*+html + !important) > !important > +html. IE7 可以是 red, blue 和 green, 但 green 的优先度最高.
Firefox 和其他浏览器都认 !important. !important 优先, Firefox 可以是 red 和 blue, 但 red 优先度高.




1 针对firefox ie6 ie7的css样式
现在大部分都是用!important来兼容,对于ie6和firefox测试可以正常显示,但是ie7对!important可以正确解释,会导致页面没按要求显示!找到一个针对IE7不错的兼容方式就是使用“*+html”,现在用IE7浏览一下,应该没有问题了现在写一个CSS可以这样:
#1 { color: #333; }  /* FF */
* html #1 { color: #666; }  /* IE6 */
*+html #1 { color: #999; }  /* IE7 */

那么在firefox下字体颜色显示为#333IE6下字体颜色显示为#666,IE7下字体颜色显示为#999。
2 css布局中的居中问题
主要的样式定义如下:
body {TEXT-ALIGN: center;}
#center { MARGIN-RIGHT: auto; MARGIN-LEFT: auto; }
说明:
首先在父级元素定义TEXT-ALIGN: center;这个的意思就是在父级元素内的内容居中;对于IE这样设定就已经可以了。
但在mozilla中不能居中。解决办法就是在子元素定义时候设定时再加上“MARGIN-RIGHT: auto;MARGIN-LEFT: auto; ”
需要说明的是,如果你想用这个方法使整个页面要居中,建议不要套在一个DIV里,你可以依次拆出多个div,只要在每个拆出的div里定义MARGIN-RIGHT: auto;MARGIN-LEFT: auto; 就可以了。





最近被IE6给搞郁闷了,做出来的东西一到IE6下就错位,但是在IE7和FireFox下面都表现得不错,让人很是头疼!真搞不明白为什么要发明那么多浏览器,微软毕竟是老大,别人发布了标准他竟然不理睬,一意孤行,可害苦了我们这些人哦!不过IE7已经比较接近WEB标准了,同时希望IE7更普及一点,大家都用IE7就不会有这么多麻烦了。
  没办法,为了兼容就得不停的在三个浏览器中测试,也总结了一些方法,记录一下以备后用;
一、CSS 兼容
  以下两种方法几乎能解决现今所有兼容:
  1、!important (不是很推荐,用下面的一种感觉最安全)。随着IE7对!important的支持, !important 方法现在只针对IE6的兼容(注意写法,记得该声明位置需要提前),代码:
  <style>
  #wrapper {
  width: 100px!important;
  width: 80px;
  }
  </style>
  2, IE6/IE77对FireFox <from 针对firefox ie6 ie7的css样式> *+html 与 *html 是IE特有的标签,firefox 暂不支持。而*+html 又为 IE7特有标签,代码:
  <style>
  #wrapper { width: 120px; }
  *html #wrapper { width: 80px;}
  *+html #wrapper { width: 60px;}
  </style>

       仅IE7识别

      *+html {…}

      当面临需要只针对IE7做样式的时候就可以采用这个兼容。

      IE6及IE6以下识别

       * html {…}

       这个地方要特别注意很多地主都写了是IE6的兼容其实IE5.x同样可以识别这个兼容。其它浏览器不识别。



  注意: *+html 对IE7的兼容 必须保证HTML顶部有如下声明:
  <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01  Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  二、万能float闭合(非常重要)可以用这个解决多个div对齐时的间距不对,关于clear float的原理可参见 [How To Clear Floats Without Structural Markup] ,将以下代码加入CSS 中,给需要闭合的div加上 class=”clearfix” 即可,屡试不爽。 代码:
:after(伪对象),设置在对象后发生的内容,通常和content配合使用,IE不支持此伪对象,非Ie 浏览器支持,所以并不影响到IE/WIN浏览器。
.clearfix:after
{
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
&n