web-dev-qa-db-ja.com

mozilla用の特定のCSSの作成方法、chromeおよびIE

IE、Mozilla、Chromeの特定のCSSを含めるために使用できるCSS条件ステートメントは何ですか。

If IE  
#container { top: 5px; }  

If Mozilla 
#container { top: 7px; }    

If Chrome  
#container { top: 9px; }

それぞれの「If」は何でしょうか?

20

そのために

  • ユーザーエージェントをスキャンし、どのブラウザとそのバージョンを見つけることができます。 OS固有のスタイルのOSを含める
  • 特定のブラウザにさまざまなCSS Hacksを使用できます
  • または、ブラウザを識別し、さまざまなクラスを要素に適用するスクリプトまたはプラグイン

PHPを使用する

見る

次に、検出されたブラウザに従って動的なCSSファイルを作成します

これがCSS Hacksリストです

/***** 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 */

ソース: http://paulirish.com/2009/browser-specific-css-hacks/

プラグインを使用したい場合は、ここに1つあります

http://rafael.adm.br/css_browser_selector/

35
Starx

Phpを使用して、ブラウザ名をbodyクラスとしてエコーできます。

<body class="mozilla">

次に、条件付きCSSは次のようになります

.ie #container { top: 5px;}
.mozilla #container { top: 5px;}
.chrome #container { top: 5px;}
8
Emmett

きれいなコードを作成するには、次のJavaScriptファイルを使用できます。 http://rafael.adm.br/css_browser_selector/ 次の行を含める

<script src="css_browser_selector.js" type="text/javascript"></script>

次の単純なパターンで後続のcssを記述できます。

.ie7 [thing] {
  background-color: orange
}
.chrome [thing] {
  background-color: gray
}
3
JellicleCat

タグにはPHPも含まれているため、サーバー側のオプションをいくつか提案します。

最も簡単な解決策は、ほとんどの人がここで提案するものです。私がこれに関して一般的に抱えている問題は、CSSファイルまたは<style>タグがhtmlドキュメントの最大20倍になり、理解できないタグの解析と処理のブラウザーの速度低下を引き起こす可能性があることです-moz-border-radius vs -webkit-border-radius

2番目の最良の解決策(見つかった)は、PHPに実際のcssファイルを出力させることです。

<link rel="stylesheet" type="text/css" href="mycss.php">

どこで

 <?php 
 header( "Content-Type:text/css"); 
 if(preg_match( "/ chrome /"、$ _SERVER ['HTTP_USER_AGENT'])) {
 // chrome特定のcssスタイルを出力します
} else {
 //デフォルトのcssスタイルを出力します
} 
?> 

これにより、ブラウザ用に小さくて簡単に処理できるファイルを作成できます。

私が見つけた最良の方法は、Apacheに固有のものです。この方法は、mod_rewriteまたはmod_PerlのPerlMapToStorageHandlerを使用して、レンダリングエンジンに基づいてURLをシステム上のファイルに再マッピングします。

あなたのウェブサイトはhttp://www.myexample.com/であり、/srv/www/htmlを指していると言ってください。 chromeの場合、main.cssを要求すると、/srv/www/html/main.cssをロードする代わりに、/srv/www/html/main.webkit.cssが存在するかどうかを確認し、存在する場合はそれをダンプし、そうでない場合はmain.cssを出力します。 IEではmain.trident.cssを試行し、firefoxではmain.gecko.cssを試行します。上記のように、より小さく、よりターゲットを絞ったcssファイルを作成できますが、ブラウザーがファイルを再ダウンロードしようとし、Webサーバーがそれを伝えるために適切な304をブラウザーに提示するため、キャッシングをより適切に使用できます、再度ダウンロードする必要はありません。また、Web開発者は、ターゲットプラットフォームにバックエンドコードを記述する必要なく、もう少し自由になります。 JavaScriptエンジンにもリダイレクトされる.jsファイルもあります。main.jsの場合、chromeではmain.v8.js、safariでは、main.nitro.js、firefoxではmain.gecko.js。これにより、より高速な特定のjavascriptの出力が可能になります(ブラウザーテストコード/機能テストが少なくなります)。開発者は特定のターゲットを設定する必要がなく、main.jsを記述でき、main.<js engine>.jsを作成できず、通常どおりロードします。つまり、main.jsおよびmain.jscript.jsファイルがあるということは、IEがjscriptを取得し、他の全員がcssファイルと同様にデフォルトのjsを取得することを意味します。

2
Rahly

cssファイルで次のコードを使用できます。

 -webkit-top:9px;  
-moz-top:7px; 
top:5px;      

コード-webkit-top:9px;はchrome用、-moz-top:7pxはmozilla用、最後はIE用です。楽しむ!!!

1
Adeel

Paul IrishのアプローチIE特定のCSSは私が見た中で最もエレガントです。条件文を使用してHTML要素にクラスを追加し、適切なIEハックに頼らずにバージョン固有のCSS CSSが検証し、今後のブラウザーバージョンで引き続き機能します。

アプローチの詳細は 彼のサイトで で見ることができます。

これは、MozillaとChromeのブラウザー固有のハックをカバーしていません...しかし、とにかくそれらが必要だとは思いません。

1
El Yobo

次のスクリプトにcssを配置し、CSSファイルに貼り付けます。

@media screenおよび(-webkit-min-device-pixel-ratio:0){完全なCSSスタイル}

例:@media screen and(-webkit-min-device-pixel-ratio:0){container {margin-top:120px;}}

魔法のように機能します。

0
pablo

このリンクを確認してください: http://webdesignerwall.com/tutorials/css-specific-for-internet-Explorer

2 Explorer固有のCSSルール(IE CSSハッキング)

もう1つのオプションは、Explorerのみが読み取れるCSSルールを宣言することです。たとえば、CSSプロパティがIE7を対象とする前にアスタリスク(*)を追加するか、プロパティがIE6を対象とする前にアンダースコアを追加します。ただし、この方法は有効なCSS構文ではないためお勧めしません。

IE8以下:CSSルールをIE8以下に具体的に記述するには、セミコロンの前にバックスラッシュと9(\ 9)を追加します。 IE7以下:CSSプロパティの前にアスタリスク(*)を追加します。 IE6:プロパティの前にアンダースコア(_)を追加します。 .box {

background: gray; /* standard */

background: pink\9; /* IE 8 and below */

*background: green; /* IE 7 and below */

_background: blue; /* IE 6 */

}

0
sudip

エージェントディテクターを使用し、Web言語でプログラムを作成してCSSを作成します

たとえば、Python

csscreator()
    useragent = detector()
    if useragent == "Firefox":
         css = "your css"
    ...
    return css
0