识别CssHack技巧-论浏览器的兼容性

csshack  时间:2021-04-22  阅读:()

兼容范围

IE:60+ FireFox:20+ Opera 100+ Sarari 30+ Chrome

参考资料

各游览器常用兼容标记一览表:

以上bb可更换为其它样式名

注意点

网上很多资料中常常把! important也作为一个hack手段其实这是一个误区。 ! important常常被我们用来更改样式而不是兼容hack。造成这个误区的原因是IE6在某些情况下不主动识别! important,以至于常常被人误用做识别IE6的hack。可是大家注意一下 IE6只是在某些情况下不识别ie6下 同一个大括号里对同一个样式属性定义其中一个加important则important标记是被忽略的例

{background:red! im portant;background:green;} ie6下解释为背景色green其它浏览器解释为背景色red如果这同一个样式在不同大括号里定义其中一个加important则important发挥正常作用例div{background:red! important}div{background:green}这时所有浏览器统一解释为背景色red。 

实例讲解

Hack应用情境一

适用范围 I E:6.0,I E7.0,I E8.0之间的兼容

实例说明

此例中我们使用了渐进识别的方式从总体中逐渐排除局部。首先巧妙的使用“\9”这一标记将

IE游览器从所有情况中分离出来。接着再次使用“+”将IE8和IE7、 IE6分离开来此时我们的IE8

已经独立识别。

实例代码bb{height:32px;background-color:#f1 ee18;/*所有识别*/background-color:#00deff\9; /*IE6、 7、 8识别*/

+background-color:#a200ff;/*IE6、 7识别*/

_background-color:#1e0bd1 ;/*IE6识别*/}

/*一个用于展示的class为bb的div标签*/

<divclass="bb"></div>

Hack应用情境二

适用范围 I E:6.0,I E7.0,I E8.0,F i refox之间的兼容

实例说明

大家很容易的可以看出这是情境一的加强版适用于更广泛的环境。其实情境一中也已经做到了把火狐与IE游览器区分开来了现在我们要做的是把火狐从其它游览器中再次识别出来。大家仔细看下代码大家会发现其实游览器识别是很简单的。火狐如何识别对了 IE中对伪类支持不广泛所以伪类是个不错的途径。 (yourClass,x:-moz-any-l ink,x:default)注意这个区分伪类往往IE7也能识别所以最好还需要把IE7单独识别出来且此方法对ff36已无效 fi refox的区分可以使用@-moz-document url-prefix(){}

实例代码bb{height:32px;background-color:#f1 ee18;/*所有识别*/background-color:#00deff\9; /*IE6、 7、 8识别*/

+background-color:#a200ff;/*IE6、 7识别*/

_background-color:#1e0bd1 ;/*IE6识别*/

}bb,x:-moz-any-l ink,x:default{background-color:#00ff00;}/*IE7 firefox35及以下识别*/

@-moz-document url-prefix(){bb{background-color:#00ff00;}}/*仅firefox识别*/

*+html bb{background-color:#a200ff;}/*仅IE7识别*/

/*一个用于展示的class为bb的div标签*/

<divclass="bb"></div>

Hack应用情境三

适用范围 IE:6.0,I E7.0,I E8.0,Firefox,Safari(Chrom e)之间的兼容

实例说明

我们现在将再次对我们的CSS进行加强了使其能识别Safari(Chrome)游览器。这是基于它们的内核webkit来识别的用法为@media screen and(-webkit-min-device-pixel-ratio:0)

实例代码bb{height:32px;background-color:#f1 ee18;/*所有识别*/background-color:#00deff\9; /*IE6、 7、 8识别*/

+background-color:#a200ff;/*IE6、 7识别*/

_background-color:#1e0bd1 ;/*IE6识别*/

}

@media screen and(-webkit-min-device-pixel-ratio:0){bb{background-color:#f1 ee18}}{}/*safari(Chrome)有效*/bb,x:-moz-any-l ink,x:default{background-color:#00ff00;}/*IE7 firefox35及以下识别*/

@-m oz-document url-prefix(){bb{background-color:#00ff00;}}/*仅firefox识别*/

*+html bb{background-color:#a200ff;}/*仅IE7识别*/

/*一个用于展示的class为bb的div标签*/

<divclass="bb"></div>

Hack应用情境四

适用范围 IE:6.0+ Fire Fox:2.0+ Opera 10.0+ Sarari 3.0+ Chrome全兼容

实例说明

实例的具体代码在下面实例代码中已经列出具体效果如此页面的顶端部分效果您可以通过不同游

览器检测该效果。这次我们基本把所有的主流游览器都兼容了大家来看下代码。Opera的识别有一部

分归功于“\0”标记这个标记只被IE8和Opera识别特殊的标记往往造就的是我们更广泛的hack

手段。下例的代码比较完整大家可以选择参考。

实例代码

<!DOCTYPE html PUBLIC"-//W3C//DTD XHTML 1 0 Transitional//EN"

"http://wwww3 org/TR/xhtml1/DTD/xhtml1-transitional dtd">

<html xmlns="http://wwww3 org/1999/xhtml" lang="gb2312">

<head>

<meta http-equiv=Content-Type content="text/html ;charset=gb2312"/>

<style type="text/css">

bb{height:32px;background-color:#f1 ee18;/*所有识别*/background-color:#00deff\9; /*IE6、 7、 8识别*/+background-color:#a200ff;/*IE6、 7识别*/_background-color:#1 e0bd1/*IE6识别*/}

@media screen and(-webkit-min-device-pixel-ratio:0){bb{background-color:#f1 ee18}}{}/*

Safari(Chrome)有效*/

@mediaal l and(min-width:0px){ bb{background-color:#f1ee18;/*operaand Safari(Chrome)andfirefox*/background-color:#4cac70\0;}/*仅Opera有效*/ }{}bb,x:-moz-any-l ink,x:default{background-color:#4eff00;/*IE7、 Firefox35及以下识别*/}

@-moz-document url-prefix(){bb{background-color:#4eff00;/*仅Firefox识别*/}}

*+html bb{background-color:#a200ff;}/*仅IE7识别*/

/*一般情况下我们区分IE7只用+background-color配合_background-color就行了如果必须写bb,x:-moz-any-l ink,x:default这样的代码区分Firefox35及以下则谨记此写法对IE7也有效故在其中要再重写一次+background-color或者使用*+html bb{background-color:blue;}方法仅对IE7有效。可使用@-m oz-document url-prefix(){}方法独立区分所有firefox*/browsers td{width:8%;text-al ign:center;padding:8px;}}browsercolor{color:#333;font-size:18px;font-weight:bold;}ie6{background-color:#1e0bd1}ie7{background-color:#a200ff}ie8{background-color:#00deff}firefox{background-color:#4eff00}opera{background-color:#4cac70}other{background-color:#f1 ee18;}

#tipTable td,#tipTable th{border:1 pxsol id black;width:56px;height:16px;text-al ign:center;}

#wordTable td{margin-left:8px;}

#firefoxTip{dis play:none;}

#firefoxTip,x:-moz-any-l ink,x:default{display:block;/*IE7 firefox35及以下识别*/+display:none/*再区分一次IE7*/}

@-moz-document url-prefix(){#firefoxTip{display:block;/*仅firefox识别*/}}

#ChromeTip{display:none;}

@media screen and(-webkit-min-device-pixel-ratio:0){#ChromeTip{display:block;}}{}/*safari(Chrome)有效*/

@media al l and(min-width:0px){#ChromeTip{display:none\0;}/*仅Opera有效*/}{}

</style>

</head>

<body>

<table class="browsers"width="100%"cel lspacing="0"cel lpadding="0">

<tr>

<td>I E 6</td>

<td></td>

<td>I E 7</td>

<td></td>

<td>I E 8</td>

<td></td>

<td>F i re fo x</td>

<td></td>

<td>O p e ra</td>

<td></td>

<td>Safari(Ch rome)</td>

<td></td>

</tr>

<tr class="browsercolor">

<tdclass="ie6">IE6</td>

<td></td>

<tdclass="ie7">IE7</td>

<td></td>

<tdclass="ie8">IE8</td>

<td></td>

<td cl ass="fi refox">Fi refox</td>

<td></td>

<tdclass="opera">Opera</td>

<td></td>

<tdclass="other">Safari(Chrome)</td>

<td></td>

</tr>

</ta b l e>

<divclass="bb">

<span style="display:none;display:block\0;display:none\9;">Opera的辨别色是深绿色 Opera游览器很时髦么。 </span>

<span id="firefoxTip">Firefox的辨别色是浅绿色 Firefox是很强大的游览器。 </span>

<span id="ChromeTip">Safari和Chrome的辨别色是金黄色 Safari和Chrome使用的都是Webkit内核</span>

<!--[if IE 8]>IE8的辨别色是蓝色新版IE8的功能可是不少呢。 <![endif]-->

<!--[if IE 7]>IE7的辨别色是紫色 IE7还可以凑合着用 <![endif]-->

<!--[if IE 6]>IE6的辨别色是红色不过 IE6可是有点落后了 <![endif]-->

</div>

</body>

</html>

HostKvm($4.25/月),俄罗斯CN2带宽大升级,俄罗斯/香港高防限量5折优惠进行中

HostKvm是一家成立于2013年的国外VPS服务商,产品基于KVM架构,数据中心包括日本、新加坡、韩国、美国、俄罗斯、中国香港等多个地区机房,均为国内直连或优化线路,延迟较低,适合建站或者远程办公等。本月,商家旗下俄罗斯、新加坡、美国、香港等节点带宽进行了大幅度升级,俄罗斯机房国内电信/联通直连,CN2线路,150Mbps(原来30Mbps)带宽起,目前俄罗斯和香港高防节点5折骨折码继续优惠中...

LOCVPS洛杉矶CN2线路KVM上线,洛杉矶/香港云地/香港邦联7折

LOCVPS发来了新的洛杉矶CN2线路主机上线通知,基于KVM架构,目前可与香港云地、香港邦联机房XEN架构主机一起适用7折优惠码,优惠后最低美国洛杉矶CN2线路KVM架构2GB内存套餐月付38.5元起。LOCPVS是一家成立较早的国人VPS服务商,目前提供洛杉矶MC、洛杉矶C3、和香港邦联、香港沙田电信、香港大埔、日本东京、日本大阪、新加坡、德国和荷兰等机房VPS主机,基于KVM或者XEN架构。...

Sharktech:美国/荷兰独立服务器,10Gbps端口/不限流量/免费DDoS防护60G,319美元/月起

sharktech怎么样?sharktech (鲨鱼机房)是一家成立于 2003 年的知名美国老牌主机商,又称鲨鱼机房或者SK 机房,一直主打高防系列产品,提供独立服务器租用业务和 VPS 主机,自营机房在美国洛杉矶、丹佛、芝加哥和荷兰阿姆斯特丹,所有产品均提供 DDoS 防护。此文只整理他们家10Gbps专用服务器,此外该系列所有服务器都受到高达 60Gbps(可升级到 100Gbps)的保护。...

csshack为你推荐
标准论文格式范例规范Sicherheitsserverhostschrome希赛网(www.educity.cn),专注软考、PMP、通信考试伺服器win7支持ipad勒索病毒win7补丁我的电脑是windows7系统,为什么打不了针对勒索病毒的补丁(杀毒软件显css下拉菜单如何使用HTML和CSS制作下拉菜单itunes备份itunes就是备份不了怎么办啊x-routerX-TRAlL是什么意思fusionchartsFusionCharts连接数据库你是怎么解决的,能告诉我吗?谢谢啦
vps推荐 vir omnis 服务器日志分析 dux 搜索引擎提交入口 最漂亮的qq空间 登陆空间 空间登陆首页 视频服务器是什么 免费的asp空间 德隆中文网 阿里云邮箱怎么注册 .htaccess 塔式服务器 sonya winserver2008 机柜尺寸 godaddy域名 俄勒冈州 更多