ホームページ > ウェブフロントエンド > CSSチュートリアル > CSS を使用して IE8 で無効になっている HTML コントロールの色を変更できないのはなぜですか?

CSS を使用して IE8 で無効になっている HTML コントロールの色を変更できないのはなぜですか?

Patricia Arquette
リリース: 2024-11-03 07:09:30
オリジナル
211 人が閲覧しました

Why Can't I Change the Color of Disabled HTML Controls in IE8 with CSS?

CSS を使用して IE8 で無効になっている HTML コントロールの色を変更する

CSS を使用して無効になっている入力コントロールの色を変更しようとしましたが、 IE8では動かないようです。その理由を理解し、デフォルトの動作をオーバーライドする方法を見つけたいと考えています。

使用した CSS:

<code class="css">input[disabled='disabled'] {
  color: #666;
}</code>
ログイン後にコピー

ほとんどのブラウザーではうまく機能しますが、IE8 では機能しません。これは、IE8 には、無効な要素に対して特定の動作があり、色のプロパティがデフォルトの灰色で上書きされ、奇妙な白い影が表示されるためです。

この理由は、IE8 で無効な要素は次のようにみなされるためです。コントロールは「非アクティブ」であり、ブラウザーはこれを示すために特定のスタイルをコントロールに適用します。残念ながら、このスタイルにはテキストに強制的な灰色が含まれており、適用しようとしている CSS がオーバーライドされます。

この動作を回避し、IE8 で無効になっているコントロールの色を変更する唯一の方法は、別の方法を使用することです。 。考えられる解決策の 1 つは、disabled 属性の代わりに :disabled 擬似クラスを使用することです。

<code class="css">input:disabled {
  color: #666;
}</code>
ログイン後にコピー

この擬似クラスは、disabled 属性が設定されている要素を対象としていますが、実際には disabled 属性は設定されません。自体。その結果、IE8 ではコントロールが「非アクティブ」であるとは見なされなくなり、デフォルトのスタイルをオーバーライドできるようになりました。

以上がCSS を使用して IE8 で無効になっている HTML コントロールの色を変更できないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート