這篇文章主要介紹了詳解CSS-opacity子元素繼承父元素透明度的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
在寫項目頁面的過程中,遇到子元素繼承父元素透明度的問題,查找了好多文檔給出的都是第一種方法,這種方法主要解決簡單場景的,而對于設(shè)置復(fù)雜的background時,該方法不再適用。
分析原因:
父元素背景顏色設(shè)置透明度opacity:0.5,子元素會繼承,給子元素設(shè)置opacity:1,子元素的透明度也是在父元素0.5的基礎(chǔ)上設(shè)置的。
第一種方法:
父元素背景顏色設(shè)置透明度時,避免使用background:#000;opacity:0.5,建議使用background:rgba(0,0,0,0.5)
第二種方法:
如果設(shè)置背景色為漸變色等這種復(fù)雜背景,第一種方法就不在適用。
background-image: linear-gradient(-180deg, rgba(20,20,20,0.00) 19%, #303030 100%);
opacity: 0.5;
因為子元素會繼承父元素的opacity屬性,我們讓它不成為子元素。新增一個子元素,將其絕對定位到父元素位置,然后在該元素上設(shè)置背景色與透明度。
<div class="container">
<div class="content">
<p>我是class為content的DIV</p>
<p>我的背景是class為background的背景</p>
<p>通過相對定位和絕對定位,我把class為background的DIV移動到了我的位置。</p>
<p>同時通過我的較大的z-index浮在了它的上面。 :)</p>
</div>
<div class="background"></div>
</div>
.container {
width: 300px;
height: 250px;
color: #fff;
position:relative;
}
.content {
position:relative;
z-index:5;
width: 100%;
height: 100%;
overflow: hidden;
}
.background {
background-color: #37a7d7;
position:absolute;
top:0px;
left:0px;
width:100%;
height:100%;
z-index:1;
/*兼容IE7、8 */
-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
filter: alpha(opacity=50);
opacity:.5;
}
文章來源:腳本之家,原文鏈接:https://www.jb51.net/css/744197.html
申請創(chuàng)業(yè)報道,分享創(chuàng)業(yè)好點子。點擊此處,共同探討創(chuàng)業(yè)新機遇!