javascript和JQuery焦点图和代码特效大全
当前最流行的开源CMS网站系统大全
当前位置:首页 > WEB前端 > CSS-HTML

兼容IE6,IE7,Firfox的CSS-hack

来源:IT技术网编辑:秩名发布于:2017-02-09人围观

简单来讲,css hack就是浏览器解析CSS时的漏洞,因此不同的浏览器就有不同的css hack写法。css hack的由来源于浏览器大战,从1995年开始,微软和网景公司的浏览器竞争,导致各自的浏览器包含大量其私有CSS属性,并逐渐远离标准。1998年网景公司以开放源代码的授权形式,把Communicator的源代码释出,以开源的形式逐渐发展一部分用户群,并在2004年推出Firefox的1.0版本。相继,Safar,Opera的用户群也正在发展壮大中。这让微软不得不考虑从新设计一款更加接近web标准的浏览器。
 
尽管微软最新推出的IE8已经对CSS2.1提供了良好的支持,但事实是,许多用户操作系统的IE版本一直停留在IE6,且大多数用户没有主动升级IE的习惯。IE的各个版本对CSS2.1中的某些属性从支持程度到解析效果,都不是很一致。这导致开发人员需要单独定义针对不同版本的的CSS样式,以此来获取相近的效果。
由此,人们发现并利用了css hack。事实上,到现在为止,我们使用css hack最主要的目的是区分IE6和IE7,IT技术网收集了一部分兼容IE6,IE7,Firfox的CSS-hack:

第一种,是CSS HACK的方法

height:20px; /*For Firefox*/
*height:25px; /*For IE7 & IE6*/
_height:20px; /*For IE6*/

注意顺序。

这样也属于CSS HACK,不过没有上面这样简洁。

#example { color: #333; } /* Moz */
* html #example { color: #666; } /* IE6 */
*+html #example { color: #999; } /* IE7 */

第二种是使用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]-->

第三种css filter的办法,以下为经典从国外网站翻译过来的。

新建一个css样式如下:

#item {
width: 200px;
height: 200px;
background: red;
}

新建一个div,并使用前面定义的css的样式:

<div id="item">some text here</div>

在body表现这里加入lang属性,中文为zh:

<body lang="en">

现在对div元素再定义一个样式:

*:lang(en) #item{
background:green !important;
}

这样做是为了用!important覆盖原来的css样式,由于:lang选择器ie7.0并不支持,所以对这句话不会有任何作用,于是也达到了ie6.0下同样的效果,但是很不幸地的是,safari同样不支持此属性,所以需要加入以下css样式:

#item:empty {
background: green !important
}

:empty选择器为css3的规范,尽管safari并不支持此规范,但是还是会选择此元素,不管是否此元素存在,现在绿色会现在在除ie各版本以外的浏览器上。

对IE6和FF的兼容可以考虑以前的!important

与相关的文章
有时间的话来看看IT界的突发事件