0

サイトの css をカスタマイズして、Mozilla がロードできるように保存したいと考えています。Mozilla がその URL から html をロードするときに、外部ファイルの代わりに私の css ファイルを使用するようにします。Mozilla にこれをさせる方法がわかりません。URL に新しいリクエストを行うと、私の代わりにサイトの css が読み込まれます。これを設定するにはどうすればよいですか?

4

3 に答える 3

1

そのために

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

jQuery の使用

あなたが求めているのは、ブラウザー検出と呼ばれるものです。

if ($.browser.mozilla) { ... 

ただし、ブラウザーのスニッフィングは、ユーザー エージェントを簡単にスプーフィング (別のブラウザーになりすます) できるため、お勧めできません。

独自の方法で、または jQuery.support インターフェイスを介して機能検出を使用することをお勧めします: http://api.jquery.com/jQuery.support/

独自の使用のために拡張する記事は次のとおりです: http://www.waytoocrowded.com/2009/03/14/jquery-supportminheight/

PHP の使用

見る

http://php.net/manual/en/function.get-browser.php
http://techpatterns.com/downloads/php-browser-detection-basic.php
http://techpatterns.com/downloads/php_browser_detection.php (contains JS also)

次に、検出されたブラウザに従って動的 CSS ファイルを作成します。これは CSS ハック リストです。

セレクターハック

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

プラグインを使用する場合は、ここにあります

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

于 2012-12-15T17:43:39.563 に答える
1

私たちのほとんどにとって最も簡単な方法は、Stylishと呼ばれる Mozilla Firefox アドオンを使用することです。特定のページまたはドメイン用に独自のスタイルシートを作成、保存、使用し、(必要に応じて) 作成者独自のルールの一部をオーバーライドできます。

内部的には、組み込みの Firefox 機能にすぎませんuserContent.css。CSS 独自のサポートされている@document構文を使用!importantし、ルールに従って、目的を正確に達成するファイルがあります。

実際、これはすべて CSS の核心です。多かれ少なかれ、ユーザーが作成者のスタイルシートをオーバーライドできるように設計されており、Firefox ではそれが多少簡単になります。

ここで、より広範な説明を得ることができます。

于 2012-12-15T17:48:59.297 に答える
0

グリースモンキー プラグインを見てみましょう: https://addons.mozilla.org/de/firefox/addon/greasemonkey/

于 2012-12-15T17:43:16.090 に答える