Home > Web Front-end > CSS Tutorial > A brief analysis of how to implement linear gradient (linear-gradient) in CSS

A brief analysis of how to implement linear gradient (linear-gradient) in CSS

青灯夜游
Release: 2022-04-02 20:16:35
forward
3695 people have browsed it

How to implement linear gradient in CSS? The following article will introduce to you how to use the CSS linear-gradient() linear gradient function, and talk about the various applications of linear gradients. I hope it will be helpful to everyone!

A brief analysis of how to implement linear gradient (linear-gradient) in CSS

linear-gradient

1. Syntax

linear- gradient([[to <direction>|<angle>],]? <color stop>, <color stop>[, ...]?)</color></color></angle></direction>

-webkit-linear-gradient([[<direction>|<angle>],]? <color stop>, <color stop>[, ...]?)</color></color></angle></direction>

These two types are different in usage and expression. When using direction, the former should be accompanied by to, and the latter without; use angle, the performance is inconsistent. [Recommended learning: css video tutorial]

1) Default

Both defaults are from top to bottom

background-image:linear-gradient(#00ffff, #ff1493, #006699);
background-image:-webkit-linear-gradient(#00ffff, #ff1493, #006699)
Copy after login

A brief analysis of how to implement linear gradient (linear-gradient) in CSS

2) <direction>: [left|right]|[top|bottom]Use of both

The opposite direction of expression

background-image:linear-gradient(to left, #00ffff, #ff1493, #006699);
background-image:-webkit-linear-gradient(left, #00ffff, #ff1493, #006699);
Copy after login

A brief analysis of how to implement linear gradient (linear-gradient) in CSS

background-image:linear-gradient(to left top, #00ffff, #ff1493, #006699);
background-image:-webkit-linear-gradient(left top, #00ffff, #ff1493, #006699);
Copy after login

A brief analysis of how to implement linear gradient (linear-gradient) in CSS

##3) The use of

Correspondence between degree and direction. -webkit-The corresponding direction is 450°-angle

##

background-image:linear-gradient(275deg, #ff1493, #000000, #006699);
background-image:-webkit-linear-gradient(175deg, #ff1493, #000000, #006699);
Copy after login
A brief analysis of how to implement linear gradient (linear-gradient) in CSS

450°-175° =275°

, so the two behave the same, as shown below:

A brief analysis of how to implement linear gradient (linear-gradient) in CSS

4)

= The use of

stop

can use a percentage or a specific value to indicate that this color reaches saturation## at this position #

background-image:linear-gradient(to right, #ff1493 10%, #000000 40%, #006699 60%);
background-image:-webkit-linear-gradient(to right, #ff1493 10%, #000000 40%, #006699 60%);
Copy after login

You can see the color change process from the picture above: A brief analysis of how to implement linear gradient (linear-gradient) in CSS

0% --> 10%: #ff1493

Has been

saturated10% --> 40%: #ff1493

gradually changes to

#000000, at 40%# At ##, #000000 reaches saturation 40% --> 60%: #000000 gradually becomes

#006699

, at 60%, #006699 reaches saturation##60% --> 100%: # 006699Always in Saturation

Using this feature, you can draw stripes

  background-image:linear-gradient(to right, #ff1493 33%, #000000 33%, #000000 66%, #006699 66%);
  background-image:-webkit-linear-gradient(to right, #ff1493 33%, #000000 33%, #000000 66%, #006699 66%);
Copy after login

Note:

stopA brief analysis of how to implement linear gradient (linear-gradient) in CSSYou can also set 2 values ​​at the same time, such as

linear-gradient(to right, #ff1493 0% 33%, #000000 33% 66%, #006699 66% 100%);-webkit- linear-gradient(to right, #ff1493 33%, #000000 33% 66%, #006699 66% 100%);

, the effect is consistent with the picture above. If the latter value is smaller than the former, the former shall prevail. As follows, 20px is smaller than 60px

, and is actually displayed as

60px. The effect is as shown below:

background-image:linear-gradient(right, #ff1493 60px, #000000 20px);
background-image:-webkit-linear-gradient(right, #ff1493 60px, #000000 20px);
Copy after login
##Extension 1: Gradient center

A brief analysis of how to implement linear gradient (linear-gradient) in CSSThe default is the center of 2 colors, but we can set it Gradient center

/* 3种颜色平分,渐变中心为1/3和2/3处 */
background-image:linear-gradient(to right, #ff1493, #000000, #006699); 
/* 渐变中心在10%和20%处 */
background-image:linear-gradient(to right, #ff1493, 10%, #000000, 20%, #006699);
Copy after login

Note: -webkit-linear-gradient

does not support this usage

Extension 2: repeating-linear-gradient

A brief analysis of how to implement linear gradient (linear-gradient) in CSSWe can use the attribute to draw repeated color blocks

background-image:repeating-linear-gradient(0deg, #ff1493, #000000 10px, #006699 20px);
background-image:-webkit-repeating-linear-gradient(0deg, #ff1493, #000000 10px, #006699 20px)
Copy after login

2. Commonly used styles

A brief analysis of how to implement linear gradient (linear-gradient) in CSS

(1) Multi-color starry sky

background-image:
    linear-gradient(45deg, rgba(255, 0, 76, 0.7), rgba(0, 0, 255, 0) 80%),
    linear-gradient(135deg, rgba(106, 0, 128, 1), rgba(0, 128, 0, 0) 80%),
    linear-gradient(225deg, rgba(0, 255, 255, 1), rgba(0, 255, 255, 0) 80%),
    linear-gradient(315deg, rgba(255, 192, 203, 0.7), rgba(255, 192, 203, 0) 80%);
Copy after login
Set multiple values ​​at the same time to make the entire background color look more gorgeous

(2) Plaid pattern

background-image:
    repeating-linear-gradient(0deg, rgba(0, 255, 255, 0.3) 0px 5px, transparent 5px 10px),
    repeating-linear-gradient(90deg, rgba(0, 255, 255, 0.3) 0px 5px, transparent 5px 10px);
    
background-image:
    repeating-linear-gradient(45deg, rgba(0, 255, 255, 0.3) 0px 5px, transparent 5px 10px),
    repeating-linear-gradient(135deg, rgba(0, 255, 255, 0.3) 0px 5px, transparent 5px 10px);
Copy after login
1A brief analysis of how to implement linear gradient (linear-gradient) in CSSUse color and transparent color to alternately render

(3)边框渐变

<div id="wrap"></div>
<style>
 #wrap {
    width: 180px;
    height: 40px;
    border: 5px solid transparent;
    border-image: linear-gradient(45deg, aqua, pink, purple) 1;
}

</style>
Copy after login

内部背景透明,但是不支持设置border-radius

1A brief analysis of how to implement linear gradient (linear-gradient) in CSS

<div id="wrap"></div>
<style>
 #wrap {
    width: 180px;
    height: 40px;
    border: 5px solid transparent;
    border-image: linear-gradient(45deg, aqua, pink, purple) 1;
    clip-path: inset(0 round 5px);
}

</style>
Copy after login

注:可以使用clip-path裁剪出圆角, 但是这种方式不适用于角度较大的圆角

1A brief analysis of how to implement linear gradient (linear-gradient) in CSS

<div id="wrap">
    <div id="content"></div>
</div>
<style>
#wrap {
    width: 180px;
    height: 40px;
    border-radius: 20px;
    background: #FFF;
    position: relative;
}

#wrap::before {
    content: &#39;&#39;;
    position: absolute;
    left: -5px;
    right: -5px;
    top: -5px;
    bottom: -5px;
    background-image: linear-gradient(45deg, aqua, pink, purple);
    border-radius: 25px;
    z-index: -1
}

/*或者*/

#wrap {
    width: 180px;
    height: 40px;
    border-radius: 20px;
    background: #FFF;
    position: relative;
    border: 5px solid transparent;
    background-origin: border-box;
    background-image: linear-gradient(#FFF, #FFF), linear-gradient(45deg, aqua, pink, purple);
    background-clip: padding-box, border-box;
}

/*或者*/

#wrap {
    width: 180px;
    height: 50px;
    border: 5px solid transparent;
    border-radius: 25px;
    background-image: linear-gradient(45deg, aqua, pink, purple);
    background-origin: border-box;
}

#content {
    width: 100%;
    height: 100%;
    border-radius: 20px;
    background: #FFF;
}

</style>
Copy after login

这几种方式都能做到圆角渐变边框,但是无法做到内部背景透明

1A brief analysis of how to implement linear gradient (linear-gradient) in CSS

(4)文字渐变

<div id="wrap"> Darker CMJ</div>
<style>
#wrap {
    font-size: 40px;
    line-height: 40px;
    font-weight: bold;
    background-clip: text;
    -webkit-background-clip: text;
    // color: transparent;
    -webkit-text-fill-color: transparent;
    background-image: linear-gradient(45deg, aqua, pink, purple);
}
</style>
Copy after login

background-clip规定背景的绘制区域,我们设置其值为text,就是在文字区域绘制,然后将文字color或者-webkit-text-fill-color设置为透明色,渐变区域就能显示出来了

1A brief analysis of how to implement linear gradient (linear-gradient) in CSS

好了,over,第一次写文章,希望能坚持下去=.=

(学习视频分享:web前端

The above is the detailed content of A brief analysis of how to implement linear gradient (linear-gradient) in CSS. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:juejin.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template