CSS-opacity实现子元素继承父元素透明度的方法有哪些?

这篇文章主要介绍了详解CSS-opacity子元素继承父元素透明度的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

在写项目页面的过程中,遇到子元素继承父元素透明度的问题,查找了好多文档给出的都是第一种方法,这种方法主要解决简单场景的,而对于设置复杂的background时,该方法不再适用。

分析原因:

父元素背景颜色设置透明度opacity:0.5,子元素会继承,给子元素设置opacity:1,子元素的透明度也是在父元素0.5的基础上设置的。

第一种方法:

父元素背景颜色设置透明度时,避免使用background:#000;opacity:0.5,建议使用background:rgba(0,0,0,0.5)

第二种方法:

如果设置背景色为渐变色等这种复杂背景,第一种方法就不在适用。

background-image: linear-gradient(-180deg, rgba(20,20,20,0.00) 19%, #303030 100%);
opacity: 0.5;

因为子元素会继承父元素的opacity属性,我们让它不成为子元素。新增一个子元素,将其绝对定位到父元素位置,然后在该元素上设置背景色与透明度。


  
  
  1. < div class=" container">
  2. < div class=" content">
  3. < p>我是 classcontentDIV</ p>
  4. < p>我的背景是 classbackground的背景</ p>
  5. < p>通过相对定位和绝对定位,我把 classbackgroundDIV移动到了我的位置。</ p>
  6. < p>同时通过我的较大的 z-index浮在了它的上面。 :)</ p>
  7. </ div>
  8. < div class=" background"></ div>
  9. </ div>
  10. .container {
  11. width: 300px;
  12. height: 250px;
  13. color: #fff;
  14. position:relative;
  15. }
  16. .content {
  17. position:relative;
  18. z-index: 5;
  19. width: 100%;
  20. height: 100%;
  21. overflow: hidden;
  22. }
  23. .background {
  24. background-color: #37a7d7;
  25. position:absolute;
  26. top: 0px;
  27. left: 0px;
  28. width: 100%;
  29. height: 100%;
  30. z-index: 1;
  31. /*兼容IE7、8 */
  32. -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
  33. filter: alpha(opacity= 50);
  34. opacity:. 5;
  35. }

 

面对国内众多的云平台,个人和企业该如何选择呢?可以参考这篇文档:【云服务器推荐】2021年腾讯云、阿里云、华为云服务器价格和配置评测

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值