Introduction to the use of CSS3 filter attribute

Introduction to the use of CSS3 filter attribute

1. Introduction

When writing animation effects for front-end pages, the filter attribute will be used more or less. Since there are too many attribute values, this article is used to organize and record its related information.

II. Introduction

The filter attribute defines a visual effect on an element (usually ).

The property values ​​are as follows:

Property Value describe
none Default value, no effect.
blur(px) Set Gaussian blur to the image. The default value is 0.
brightness(%) Applies a linear multiplication to the image, making it appear brighter or darker. The default value is 1.
contrast(%) Adjust the contrast of the image. The default value is 1.
grayscale(%) Convert the image to grayscale. The default value is 0.
hue-rotate(deg) Applies hue rotation to the image. The default value is 0deg.
invert(%) Invert the input image. The default value is 0.
opacity(%) The transparency level of the converted image. The default value is 1.
Saturate(%) Convert image saturation, the default value is 1.
sepia(%) Convert the image to sepia. The default value is 0.

Note: Filters are usually expressed as percentages (such as 75%), but can also be expressed as decimals (such as 0.75).

3. Demonstration Code

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .container {
            margin: 4rem auto;
            width: 100%;
            height: auto;
            text-align: center;
        }

        .box {
            display: inline-block;
            margin: 1rem;
        }

        .box ul {
            margin: 0;
            padding: 0;
            list-style: none;
            text-align: left;
        }

        .box ul li {
            margin: .25rem 0;
            padding: .25rem;
            cursor: pointer;
        }

        .box ul li:hover {
            background-color: #eee;
        }

        ul li.active {
            background-color: #eee;
        }

       .box img {
            width: 260px;
            height: 260px;
        }

    </style>
</head>
<body>
    <div class="container">
        <h3>Click on the left side to display the properties</h3>
        <div class="box">
            <ul>
                <li data-p="blur(5px)">filter: blur(5px)</li>
                <li data-p="brightness(.5)">filter: brightness(.5)</li>
                <li data-p="contrast(.5)">filter: contrast(.5)</li>
                filter: grayscale(1)
                <li data-p="hue-rotate(90deg)">filter: hue-rotate(90deg)</li>
                <li data-p="invert(.4)">filter: invert(.4)</li>
                <li data-p="opacity(.4)">filter: opacity(.4)</li>
                filter: saturate(.5)
                <li data-p="sepia(.5)">filter: sepia(.5)</li>
            </ul>
        </div>
        <div class="box">
            <div class="origin">
                <img src="upload/2022/web/87c01ec7gy1frmmmwb3anj21hc0u0b2a.jpg" alt="">
            </div>
            <div>Original image</div>
        </div>
        <div class="box">
            <div id="filter">
                <img src="upload/2022/web/87c01ec7gy1frmmmwb3anj21hc0u0b2a.jpg" alt="">
            </div>
            <div id="info">Effect diagram</div>
        </div>
    </div>
    <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.min.js"></script>
    <script>
        $(function() {
                let $lis = $("li");
               $lis.on("click", function() {
                    $lis.removeClass("active");
                    let p = $(this).addClass("active").data("p");
                    $("#filter").css({"filter": p});
                    $("#info").text("filter: " + p);
               });
        });
    </script>
</body>
</html>

The above is the detailed introduction to the use of CSS3 filter attributes. For more information about CSS3 filter attributes, please pay attention to other related articles on 123WORDPRESS.COM!

<<:  A brief discussion on the problem that the text in the button is not centered vertically in the browser's compatibility mode

>>:  Pygame code to make a snake game

Recommend

Implementation of Docker deployment of MySQL cluster

Disadvantages of single-node database Large-scale...

Detailed explanation of MySQL data rows and row overflow mechanism

1. What are the formats of lines? You can see you...

XHTML three document type declarations

XHTML defines three document type declarations. T...

MySQL database architecture details

Table of contents 1. MySQL Architecture 2. Networ...

JavaScript to achieve elastic navigation effect

This article shares the specific code for JavaScr...

isPrototypeOf Function in JavaScript

Table of contents 1. isPrototypeOf() Example 1, O...

Docker network principles and detailed analysis of custom networks

Docker virtualizes a bridge on the host machine. ...

How to implement distributed transactions in MySQL XA

Table of contents Preface XA Protocol How to impl...

In-depth explanation of iterators in ECMAScript

Table of contents Preface Earlier iterations Iter...

Solution to the problem of data loss when using Replace operation in MySQL

Preface The company's developers used the rep...

Navicat for MySql Visual Import CSV File

This article shares the specific code of Navicat ...

How to create a web wireframe using Photoshop

This post introduces a set of free Photoshop wire...

The problem of Vue+tsx using slot is not replaced

Table of contents Preface Find the problem solve ...