さまざまなブラウザーのページ (index.html など) に一意のプロパティを付与したい場合。例: Chrome の場合は青色の背景、Firefox の場合は赤色の背景の場合、この場合に CSS コードを記述するにはどうすればよいでしょうか?
user1780677
質問する
29344 次
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
まず、ブラウザのスニッフィングは悪質であり、ほぼ確実に後悔するでしょう。
ただし、必要に応じて、次のようにサーバー側で実行できます。.htaccess を使用したブラウザー スニッフィング
ただし、理想的には、古いバージョンの IE を処理するために HTML で条件付きコメントを使用するというベスト プラクティスに固執し、意図的にクロスブラウザーで一貫して動作する 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 に答える