4

如果我想为不同浏览器的页面(比如 index.html)赋予一个独特的属性。例如:Chrome 的蓝色背景和 Firefox 的红色背景,那么我该如何为这种情况编写 CSS 代码?

4

4 回答 4

10

使用 CSS 媒体查询 (Chrome/Safari)

@media not all and (-webkit-min-device-pixel-ratio:0)
{  
    #example
    {
        width: 200px;
    }
}

Chrome/Safari 特定的 css 文件 (Chrome/Safari)

<link rel="stylesheet" href="style-sheet_chrome.css" type="text/chrome/safari" />

这是一个 CSS 黑客列表

/***** Selector Hacks ******/

/* IE6 and below */
* html #uno  { color: red }

/* IE7 */
*:first-child+html #dos { color: red } 

/* IE7, FF, Saf, Opera  */
html>body #tres { color: red }

/* IE8, FF, Saf, Opera (Everything but IE 6,7) */
html>/**/body #cuatro { color: red }

/* Opera 9.27 and below, safari 2 */
html:first-child #cinco { color: red }

/* Safari 2-3 */
html[xmlns*=""] body:last-child #seis { color: red }

/* safari 3+, chrome 1+, opera9+, ff 3.5+ */
body:nth-of-type(1) #siete { color: red }

/* safari 3+, chrome 1+, opera9+, ff 3.5+ */
body:first-of-type #ocho {  color: red }

/* saf3+, chrome1+ */
@media screen and (-webkit-min-device-pixel-ratio:0) {
 #diez  { color: red  }
}

/* iPhone / mobile webkit */
@media screen and (max-device-width: 480px) {
 #veintiseis { color: red  }
}


/* Safari 2 - 3.1 */
html[xmlns*=""]:root #trece  { color: red  }

/* Safari 2 - 3.1, Opera 9.25 */
*|html[xmlns*=""] #catorce { color: red  }

/* Everything but IE6-8 */
:root *> #quince { color: red  }

/* IE7 */
*+html #dieciocho {  color: red }

/* Firefox only. 1+ */
#veinticuatro,  x:-moz-any-link  { color: red }

/* Firefox 3.0+ */
#veinticinco,  x:-moz-any-link, x:default  { color: red  }



/***** Attribute Hacks ******/

/* IE6 */
#once { _color: blue }

/* IE6, IE7 */
#doce { *color: blue; /* or #color: blue */ }

/* Everything but IE6 */
#diecisiete { color/**/: blue }

/* IE6, IE7, IE8 */
#diecinueve { color: blue\9; }

/* IE7, IE8 */
#veinte { color/*\**/: blue\9; }

/* IE6, IE7 -- acts as an !important */
#veintesiete { color: blue !ie; } /* string after ! can be anything */
于 2012-10-28T15:27:24.703 回答
5

首先,浏览器嗅探很糟糕,你几乎肯定会后悔这样做。

但是,如果必须,您可以像这样在服务器端进行:Browser sniffing with .htaccess

理想情况下,坚持最佳实践,即在 HTML 中使用条件注释来处理旧版本的 IE,并编写有意跨浏览器始终如一地工作的 CSS。

于 2012-10-28T11:29:54.333 回答
0

你可以试试这个:

<script type="text/javascript">
var browser=navigator.appName;
if browser == "Microsoft Internet Explorer" {
document.write("<link type=\"text/css\" rel=\"stylesheet\" href=\"IE.css\">");
}
else if browser == "Firefox" {
document.write("<link type=\"text/css\" rel=\"stylesheet\" href=\"FF.css\">");
}
else {
document.write("<link type=\"text/css\" rel=\"stylesheet\" href=\"generic.css\">");
}
</script>

来源:https ://stackoverflow.com/a/1706221/1087653

或者您可以使用以下命令:

<!--[if IE 6]> 
<link rel="stylesheet" type="text/css" href="iespecific.css" />
<![endif]-->

<![if !IE]>
<link rel="stylesheet" type="text/css" href="not-ie.css" />
<![endif]>
于 2012-10-28T11:20:28.413 回答
0

<link rel="stylesheet" href="style-sheet_chrome.css" type="text/chrome/safari">

这是 WebKit/Blink 中的一个错误,Chrome 计划在版本 50 中修复它,因此它将不再工作。

http://code.google.com/p/chromium/issues/detail?id=286682

https://groups.google.com/a/chromium.org/forum/m/#!topic/blink-dev/nH1O6WszMgo

于 2016-01-18T20:33:41.753 回答