Detailed explanation of the solution for CSS-opacity child elements to inherit the transparency of parent elements

Detailed explanation of the solution for CSS-opacity child elements to inherit the transparency of parent elements

In the process of writing the project page, I encountered the problem of child elements inheriting the transparency of parent elements. I searched a lot of documents and they all gave the first method. This method mainly solves simple scenes, but it is no longer applicable when setting a complex background.

Analysis of the reasons:

If the background color of the parent element is set to opacity: 0.5, the child element will inherit it. If opacity: 1 is set for the child element, the transparency of the child element is also set based on the parent element's 0.5.

First method:

When setting the transparency of the parent element background color, avoid using background: #000; opacity: 0.5. It is recommended to use background: rgba(0,0,0,0.5)

Second method:

If the background color is set to a complex background such as a gradient color, the first method is no longer applicable.

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

Because child elements inherit the opacity property of their parent elements, we make it not a child element. Add a child element, absolutely position it to the parent element, and then set the background color and transparency on the element.

<div class="container">
    <div class="content">
        <p>I am a DIV with class content</p>
        <p>My background is the background of class background</p>
        <p>Through relative positioning and absolute positioning, I moved the DIV with class background to my position. </p>
        <p>At the same time, my larger z-index makes it float on top of it. :)</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;
    /*Compatible with IE7, 8 */
       -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
    filter: alpha(opacity=50);
    opacity:.5;
}

Reference: https://www.cnblogs.com/liu-l/p/3890861.html

This concludes this article on the solution to how CSS-opacity child elements inherit the transparency of parent elements. For more information about CSS-opacity child elements inheriting the transparency of parent elements, please search previous articles on 123WORDPRESS.COM or continue to browse the related articles below. We hope that you will support 123WORDPRESS.COM in the future!

<<:  Detailed tutorial on installing Docker on CentOS 8.4

>>:  7 cool dynamic website designs for inspiration

Recommend

How to create Apache image using Dockerfile

Table of contents 1. Docker Image 2. Create an in...

How to install and configure GitLab on Ubuntu 20.04

introduce GitLab CE or Community Edition is an op...

CentOS system rpm installation and configuration of Nginx

Table of contents CentOS rpm installation and con...

XHTML Getting Started Tutorial: Commonly Used XHTML Tags

<br />Just like an article, our web pages sh...

Perfect solution to MySQL common insufficient memory startup failure

1. If MySQL is not started successfully, check th...

Learn about CSS label display mode in one article

Tag type (display mode) HTML tags are generally d...

Implementation of mounting NFS shared directory in Docker container

Previously, https://www.jb51.net/article/205922.h...

MySQL tutorial DML data manipulation language example detailed explanation

Table of contents 1. Data Manipulation Language (...

HTML validate HTML validation

HTML validate refers to HTML validation. It is the...

Mybatis implements SQL query interception and modification details

Preface One of the functions of an interceptor is...

How to recover accidentally deleted messages files in Linux

If there are files that are being used by a proce...

MySQL horizontal and vertical table conversion operation implementation method

This article uses examples to illustrate how to i...

Understanding of haslaylout and bfc parsing

1. haslayout and bfc are IE-specific and standard ...

Detailed explanation of how to configure static IP in Centos8

After installing centos 8, the following error wi...