天天看点

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

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

这篇文章主要介绍了详解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>我是 class为 content的 DIV</ p>
  4. < p>我的背景是 class为 background的背景</ p>
  5. < p>通过相对定位和绝对定位,我把 class为 background的 DIV移动到了我的位置。</ p>
  6. < p>同时通过我的较大的 z-index浮在了它的上面。 :)</ p>
  7. </ div>
  8. < div class=" background"></ div>
  9. </ div>
  10. .container {
  11. width: ;
  12. height: ;
  13. color: ;
  14. position:relative;
  15. }
  16. .content {
  17. position:relative;
  18. z-index: ;
  19. width: ;
  20. height: ;
  21. overflow: hidden;
  22. }
  23. .background {
  24. background-color: ;
  25. position:absolute;
  26. top: ;
  27. left: ;
  28. width: ;
  29. height: ;
  30. z-index: ;
  31. /*兼容IE7、8 */
  32. -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
  33. filter: alpha(opacity= );
  34. opacity:. ;
  35. }