子要素の継承された不透明度をオーバーライドする
Web 開発では、親要素の不透明度を設定すると、その子要素にも影響を与える可能性があります。ただし、特定の子要素に対してこの継承を防止したい場合があります。
次のコードを検討してください:
<div class="parent"> <div class="child"></div> </div> .parent { opacity: 0.6; }
この場合、子要素にも不透明度が設定されます。完全に不透明のままにしたい場合でも、0.6 の値を指定します。どうすればこれを克服できますか?
不透明度の計算を理解する
CSS で不透明度がどのように計算されるかを理解することが重要です。子要素の不透明度を 1 に設定するだけでは、継承された不透明度はキャンセルされません。これは、不透明度が子の不透明度とその祖先要素の不透明度の積として計算されるためです。
たとえば、親要素の不透明度が 0.5 で、子要素の不透明度が 1 の場合、子要素の実効不透明度は 0.5 のままです。
Solutions
1。子を親から移動する:
最も簡単な解決策は、親の直接の子孫から子要素を削除することです。こうすることで、親の不透明度は継承されなくなります。
2. RGBA カラーを使用する:
不透明度の代わりに、親要素の背景または境界線に RGBA カラーを使用することを検討してください。 RGBA カラーでは、アルファ (透明度) 値と RGB (カラー) 値の両方を指定できます。アルファ値を調整すると、子要素に影響を与えることなく、不透明度と同様の効果を実現できます。
注意事項:
これらのソリューションは継承された不透明度の問題を解決しますが、それらには制限があることは注目に値します。子要素を親要素の外に移動すると、ページのレイアウトや機能が変更される可能性があり、RGBA カラーを使用しても、不透明度と同じ外観が提供されない可能性があります。
以上がCSS で子要素が親要素から不透明度を継承しないようにするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。