CSS Hack的基本原理和实现方式
创始人
2024-07-14 02:20:17
0

本文向大家简单介绍一下CSS Hack的基本原理和实现方式,有人说CSS hack是一种类似作弊的手段,以欺骗浏览器的方式达到兼容的目的,是用浏览器的兼容性差异来解决浏览器的兼容性问题,CSS hack是因为现有浏览器对标准的解析不同,为了兼容各浏览器,所采用的一种补救方法。

CSS Hack的基本原理和实现方式

由于不同的浏览器,比如IE6、IE7、IE8、Firefox等,对CSS解析的标准不同,因此对于相同的CSS代码,可能会生成不同的页面效果,从而无法在所有浏览器中得到我们想要的效果。这时,我们就需要针对不同的浏览器去写不同的CSS代码,让它能够在所有浏览器中获得相同的效果。这个过程,就是CSS hack。也就是写出只有个别浏览器或某些浏览器识别的CSS代码。

CSS Hack的基本原理

CSS hack是因为现有浏览器对标准的解析不同,为了兼容各浏览器,所采用的一种补救方法。

CSS hack是一种类似作弊的手段,以欺骗浏览器的方式达到兼容的目的,是用浏览器的兼容性差异来解决浏览器的兼容性问题。因此,在设计之初,写CSS hack需要遵循以下三条原则:

◆有效:能够通过Web标准的验证

◆只针对太古老的/不再开发的/已被抛弃的浏览器,而不是目前的主流浏览器

◆代码要丑陋。让人记住这是一个不得已而为之的Hack,时刻记住要想办法去掉它。

现在很多hacks已经抛弃了最初的原则,而滥用hack会导致浏览器更新之后产生更多的兼容性问题。因此,并不推荐使用CSS hack来解决兼容性问题。#p#

CSS hack的实现方式

我总结了一下,实现CSS hack大概有以下几种方式:

1.利用浏览器对相同代码的解析和支持的不同实现的hack

不同浏览器对相同的CSS代码的支持情况可能不同。尤其是对错误的写法。

例如

CSScode

  1. #test{  
  2. _width:80px;  
  3. }  
  4.  

在IE7及以上版本的浏览器中会被当作错误特性而舍弃,但是在IE6中可以被正常的解析。这时候,可以把_width当作hack,专门针对IE6来设置元素的宽度。

2.以Firefox或Webkit特有的扩展样式实现的hack

以-moz或-webkit开头的扩展样式,是浏览器对CSS标准的扩展。这些特性只在相应的浏览器里才可以被正常的解析。因此可以被当作CSS hack来使用。

◆以-moz开头的Firefox特有扩展样式

Mozilla浏览器支持的一些扩展是以-moz开头的。这些扩展包括了一些功能,例如圆形边界等。这种CSS只适用于Mozilla浏览器。
比如,-moz-opacity是在Firefox2.0版本出现的特性,用来实现元素的透明,但Firefox3.0以后的版本中不再支持,而是直接支持标准中的opacity特性。而其他浏览器不支持-moz-opacity。所以,可以使用-moz-opacity来针对Firefox2.0设置元素的透明度。
关于Firefox扩展样式的详细信息,见MozillaCSSExtensions。

◆以-webkit开头的Webkit浏览器特有扩展样式

与以-moz开头的Firefox特有扩展样式相同,以-webkit开头的样式是Webkit浏览器特有的,只有Webkit浏览器可以解析。
比如,在Webkit浏览器中可以用-webkit-border-radius实现圆角。

3.利用IE对标准的支持缺陷写的CSS hack

这个类别以中的hack以IE对标准的支持缺陷为基础,可以让CSS代码针对IE6或IE7以外的浏览器生效。
例如,!important只有IE7及以上版本的IE及其他浏览器支持,所以,可以用!important来针对IE6以外的浏览器写CSS代码;再如,head:first-child+bodyselector,:first-child不被IE6支持,所以可以用来针对IE6以外的浏览器编写CSS代码。
此处不在一一列举。

当然,有的观点认为应用CSS2.1标准,不属于CSS hack。见Tantek'sThoughts,UsingACSS2FeatureIsNOTaHack。

4.以IE特有的条件注释为基础的hack

IE浏览器中特有的条件注释也经常被用作hack,可以针对特定版本的IE写CSS代码。

例如,测试用例:

  1. HTMLcode 
  2. TEXT 
  3.  

以上代码中的"TEXT",只在IE8中才会是红色。

【编辑推荐】

  1. 调用CSS hack区分不同浏览器
  2. CSS hack:实现IE6、IE7、Firefox兼容
  3. 深入探究DIV CSS布局中position属性用法
  4. CSS属性display:inline-block使用揭秘
  5. Firefox、IE7、IE6浏览器兼容问题概念解析

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...