当前位置: 首页 > 图文教程 > 网页制作 > CSS样式表 > CSS Hack兼容各浏览器是否正常

CSS样式表
CSS 书写有怎样的功能
FireFox中上层高度不影下层的解决办法
CSS text-shadow属性
CSS @import与link的具体区别
详解css 定位与定位应用
网页设计新手30条进阶秘技
CSS分栏布局的方法:绝对定位和浮动
针对IE8正式版的CSS hack
条件 CSS的使用
CSS 垂直居中五种实现方法
CSS教程 汇总让IE6崩溃的几种方法
左上角图片文字环绕在图片右侧
鼠标指向网页图片时图片周围显示虚线框
CSS 快速提升设计可读性和维护性
CSS3 完美实现圆角效果
网页排版 5个CSS基础
CSS3 圆角效果
HTML5 CSS3给网站设计带来出色效果
CSS 网页布局 表格制作实例
css 滚动条换色调整代码

CSS样式表 中的 CSS Hack兼容各浏览器是否正常


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-30   浏览: 136 ::
收藏到网摘: n/a

CSS Hack是在标准 CSS 没办法兼容各浏览器显示效果时才会用上的补救方法,我们在ruanchen.com中不泛深入介绍CSS兼容性的文章。在各浏览器厂商解析 CSS 没有达成一致前,我们只能用这样的方法来完成这样的任务。
  在ruanchen.com上你可能能搜索到一大堆的 CSS Hack,但是我今天发布的你可能并不都很了解,因为这些都是只针对单独一个浏览器的 CSS Hack。为了向你展示这些 CSS Hack 是否正常运作,我新建六个 P 标签,并给每一个 P 标签一个特有的 id。这将向你展示 CSS Hack 的运作情况。

<p id="opera">我来自 Opera 7.2 - 9.5</p> 
<p id="safari">我是神奇的 Safari</p> 
<p id="firefox">我来自 Firefox</p> 
<p id="firefox12">我是你爷爷 Firefox 1 - 2 </p>
 <p id="ie7">我是囧 IE 7</p> 
<p id="ie6">我是脑瘸 IE 6</p> 

  然后我让这些 P 标签默认都不显示

<style type="text/css"> body p{display: none;} </style> 

  使用 IE CSS 条件注释区分 IE 浏览器
  最简单的区分 IE 浏览器的方法自然是使用他们的条件注释。 微软创建了一个强大的语法来让我们去实现这个功能。我不想再详细地介绍 IE 条件注释了,我想你在搜索引擎能搜索到上万个搜索条目,我这里只要这两个:

<!--[if IE 7]> 
<style type="text/css"> 
</style> <![endif]-->
 <!--[if IE 6]> 
<style type="text/css"> </style> 
<![endif]--> 

  使用 CSS 解析器 Hacks 区分 IE
  虽说 IE 条件注释十分简单好用,但是如果你想把全部的 CSS 放到一个文件里的话,那么你不得不使用别的方法。注意这里的 IE 7 Hack将只对 IE7 有效,因为 IE6 根本不知道 > 选择符。同时你也得注意 > 选择符对于其他浏览器同样是无效的。

 html > body #ie7 {*display: block;} 
 body #ie6 {_display: block;}
 
  CSS Hack 区分 Firefox
  第一个使用了 body:empty 来区分 Firefox 1 和 2 。第二个 hack使用了全部 Firefox 浏览器的专有扩展 -moz。 -moz 只对 Firefox有效,使用这个 Hack 大可不必担心其他浏览器的影响。

body:empty #firefox12 {display: block;}
@-moz-document url-prefix() {#firefox { display: block; }}  

  CSS Hack 区分 Safari
  Safari 的 CSS hack 与 Firefox 的 hack 看起来很像,使用的是 Safari浏览器的专有扩展 -webkit 且只对 Safari 浏览器有效。

@media screen and (-webkit-min-device-pixel-ratio:0) {#safari { display: block; }} 

  CSS Hack 区分 Opera
 
@media all and (-webkit-min-device-pixel-ratio:10000), not all and (-webkit-min-device-pixel-ratio:0) {head~body #opera { display: block; }} 

  然后,全部合在一起便是

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>CSS Browser Hacks - ruanchen.com</title>
<style type="text/css">
body p {
    display: none;
}


html:first-child #opera {
    display: block;
}

 html > body #ie7 {
*display: block;
}

 body #ie6 {
    _display: block;
}

body:empty #firefox12 {
    display: block;
}
 
@-moz-document url-prefix() {
 #firefox {
    display: block;
}
}


@media screen and (-webkit-min-device-pixel-ratio:0) {
#safari {
display: block;
}
}

@media all and (-webkit-min-device-pixel-ratio:10000), not all and (-webkit-min-device-pixel-ratio:0) {
head~body #opera {
display: block;
}
}
</style>
</head>
<body>
<p id="opera">我来自 Opera 7.2 - 9.5</p>
<p id="safari">我是神奇的 Safari</p>
<p id="firefox">我来自 Firefox</p>
<p id="firefox12">我是你爷爷 Firefox 1 - 2 </p>
<p id="ie7">我是囧 IE 7</p>
<p id="ie6">我是脑瘸 IE 6</p>
</body>
</html>
 
  CSS Hack 虽好且方便兼容各浏览器,但是通不过 W3C 验证,所以还得自己权衡是否有必要去使用。