ホームページ  >  記事  >  ウェブフロントエンド  >  インライン スタイルを使用する場合、競合する CSS ルールを外部スタイルシートからオーバーライドするにはどうすればよいですか?

インライン スタイルを使用する場合、競合する CSS ルールを外部スタイルシートからオーバーライドするにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2024-10-30 03:39:28183ブラウズ

How can I override a conflicting CSS rule from an external stylesheet when using inline styling?

CSS の優先順位: 特異性について

このシナリオでは、rightColumn ID の表のセルに適用されるインライン スタイルの padding-left: 10px が、競合するルールによってオーバーライドされます。外部スタイルシートから。参照されるスタイルシートには、rightColumn クラス内のすべての要素のマージンとパディングを 0 に設定するルールが含まれています。

CSS の特異性の概念

どの CSS ルールが優先されるかを決定するには、特異性と呼ばれる概念が必要です。が登場します。特異性は、CSS ルールのセレクターがどの程度具体的であるかを示す尺度です。セレクターがより具体的であるほど、その特異性は高くなります。

特異性の計算

CSS 2.1 では、特異性を計算するための次のルールが定義されています。

  • 宣言が次の場合は 1 をカウントします。スタイル属性 (インライン スタイル) から、スタイル属性からでない場合は 0。
  • セレクター内の ID 属性の数をカウントします。
  • 他の属性と疑似クラスの数をカウントします。
  • セレクター内の要素名と疑似要素の数をカウントします。

これら 4 つの値は、a-b-c-d の形式で連結されます。ここで、a は、最初のルールから b、2 番目のルールから b というようになります。数値が大きいほど、特異性が高くなります。

指定されたケースに特異性を適用する

この場合、インライン スタイルの特異性は 0001 (ID 属性、その他の属性、または疑似クラス、1 つの要素名)。外部スタイルシートからの競合するルールの特異性は 0010 (ID 属性なし、他の属性または疑似クラスが 1 つ、要素名なし) です。

0010 は 0001 より大きいため、外部スタイルシートからのルールは次のようになります。

特異性の問題を克服するための 2 つの解決策

競合するルールをオーバーライドするには、主に 2 つのオプションがあります。

  1. 使用! important: インライン スタイルに ! important を追加すると、その重要性が高まり、競合するルールがオーバーライドされます。ただし、混乱を招く可能性があるため、これは慎重に使用する必要があります。
  2. より詳細なセレクターを使用する: 問題のテーブル セルにクラスまたは ID を追加して、インライン スタイルを変更します。これにより、外部スタイルシートの競合するルールよりも高い特異性を持つ新しいルールが作成されます。

以上がインライン スタイルを使用する場合、競合する CSS ルールを外部スタイルシートからオーバーライドするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。