CSS3 sets a mask for the background image and solves the problem of mask style inheritance

CSS3 sets a mask for the background image and solves the problem of mask style inheritance

In many cases, you need to process the background of the picture, such as setting transparency, blurring, etc.

However, if you set these effects directly on the tag where the background image is located, these styles will be inherited by the child tags.

Example 1: Setting a blur effect on the background label affects the text in the sub-labels

   <style>
        .parent{
            background: url('./test.jpg') no-repeat center;
            filter: blur(3px)
        }
        .son{
            filter: blur(0);
            /*
            Setting the same attribute in a child tag cannot override the inherited style*/
        }
    </style>

    <div class="parent">
        <p class="son">Hello</p>
    </div>

Solution:

Add a tag to the parent tag, make it absolutely positioned and fill the parent tag, and set the background/style in the tag.

   <style>
        .parent{
            position: relative;
            /*Let the parent tag be relatively positioned, and let .middle be relatively positioned*/
        }
        .middle{
            background: url('./test.jpg') no-repeat center;
            filter: blur(3px);

            position: absolute;
            height: 100%;
            width: 100%;
            
            z-index: -1;
            /*Reduce the layer height to prevent covering other sub-elements*/
        }
        .son{
        }
    </style>
    
    <div class="parent">
        <div class="middle"></div>
        <p class="son">Hello</p>
    </div>

This concludes the article on how to set a mask for a background image using CSS3 and solve the problem of mask style inheritance. For more information on CSS3 background image masking, please search previous articles on 123WORDPRESS.COM or continue browsing the following related articles. I hope you will support 123WORDPRESS.COM in the future!

<<:  Introduction to the difference between OBJECT and EMBED tags used to display flash content

>>:  Detailed explanation of the new array methods in JavaScript es6

Recommend

Ubuntu opens port 22

Scenario You need to use the xshell tool to conne...

8 powerful techniques for HTML web page creation

<br />Although there are many web page creat...

Implement a simple data response system

Table of contents 1. Dep 2. Understand obverser 3...

How to quickly delete all tables in MySQL without deleting the database

This article uses an example to describe how to q...

Vue implements a movable floating button

This article example shares the specific code of ...

Analysis of MySQL latency issues and data flushing strategy process

Table of contents 1. MySQL replication process 2....

Detailed analysis of MySQL 8.0 memory consumption

Table of contents 1. innodb_buffer_pool_size 2. i...

How to use Docker-compose to deploy Django applications offline

Table of contents Install Docker-ce for the devel...

W3C Tutorial (7): W3C XSL Activities

A style sheet describes how a document should be ...

21 MySQL standardization and optimization best practices!

Preface Every good habit is a treasure. This arti...

Problems with using multiple single quotes and triple quotes in MySQL concat

When dynamically concatenating strings, we often ...

React+Typescript implements countdown hook method

First, setInterval is encapsulated as a Hook 👇 im...

A friendly alternative to find in Linux (fd command)

The fd command provides a simple and straightforw...