preface
Usually, background: Linear-gradient (Red, yellow) is used to set the gradient color. I have not studied the other gradient colors in depth, and I will not know the other . Today, I will summarize its use method, and it is convenient to refer to it in the future.
linear-gradient()
define
The CSS Linear-gradient () function is used to create an image that represents a linear gradient of two or more colors. The result is a data type and is a special kindData type.
First of all, let’s take a look at what is Linear-gradient (). According to the definition of MDN, it is a picture. We can create pictures generated by several color transitions through the linear-gradient() function.
After understanding the nature of Linear-gradient (), let’s look at background: Linear-gradient (Red, yellow). Since the function generates a picture, We can also use background-image: repeating-Linear-gradient (Blue, Green); To introduce images. Background-size :16px 16px; To set the size of the background image and so on.
grammar
linear-gradient(angle | to
,
angle | to <side-or-corner>
Single pipe |. Means exclusive. Attribute values before and after the symbol are supported and cannot occur at the same time. Can be Angle,
one of them.
/ / Angle is zero90deg
.box{
background:linear-gradient(90deg,red,yellow);
}
Copy the code
Look at the side – or – corner > = [left | right] | | [top] | bottom
[] indicates the range. That is, the values of the supported attributes are in this range. | | said can use separate legal continue to see before and after the < side – or – corner > the | | optional values can be divided into [left | right] and [the top] | bottom before and after two parts, the two parts can appear at the same time. So here are the following
- to left
- to right
- to top
- to bottom
- left top
- left bottom
- right top
- right bottom
<color> [ <color-stop-length> ]?
- ?
is optional.
- [] specifies the range of values that are supported. Only
- [< < color – stop – length > = percentage > | < length >] {1, 2}
- Support percentage and length, used in the same [] | single pipe, can only choose one type.
- {} represents the number of values, similar to regular syntax. Note There can be either 1 percentage or 2 percentage (same with length).
.box{/ / supportcolor-stop-lenght is a valuebackground:linear-gradient(to right,red 10% ,yellow 90%); / / supportcolor- stop - lenght2In this case, use percentage and length separatelybackground:linear-gradient(to right,red 10% ,70%,yellow 90% 100%);
}
Copy the code
Set transition direction
Let’s look at some examples
background:linear-gradient(0deg,red,yellow)
When deG is set to 0, red -> yellow goes from bottom to top
background:linear-gradient(90deg,red,yellow);
background-image:linear-gradient(red, yellow)
Color – stop – length setting
When color-stop-length is set to a single value
0-20% display red, 20%-80% transition, and 80%-100% display yellow
When color-stop-length is set to two values
0-20% green, 20%-50% red, 50%-70% transition,70%-80% yellow, because there is no color behind 80%-100% yellow
Set multiple Linear-gradients ()
Multiple Linear-gradient () level problems
Here we set the first Linear-gradient () to red, and set the gradient stop color opacity to 0, so that the underground blue can be seen through transparency. If we do not set the stop color opacity, the blue will be completely covered. Therefore, it can be concluded that the linear-gradient added first has a higher level.
. Box {background: linear - gradient (0 deg, rgba (255,0,0,1), rgba (255,0,0,0) 50%). Linear - gradient (180 deg, rgba (0,0,255,1), rgba,0,255,1) (0 100%); }Copy the code
Multiple Linear-gradients () effects
.box{
background: linear-gradient(45deg, red ,rgba(255.0.0.0) 90%),
linear-gradient(225deg.rgba(67.241.67.0.8), rgba(67.241.67.0) 90%),
linear-gradient(135deg.rgba(255.255.0.0.8),rgba(255.255.0.0) 90%),
linear-gradient(-45deg.rgba(0.0.255.0.8),rgba(0.0.255.0) 90%);
}
Copy the code
repeating-linear-gradient
define
The CSS function repeating-Linear-gradient () creates a repeating linear gradientThis is a function similar to Linear-gradient and takes the same parameter, but it repeats gradients in all directions to cover its entire container. The result of this function is an object of data type, which is specialType.
Repeating-linear-gradient () the CSS function also creates a gradient image. If the background image is not filled with the background, it will automatically repeat. In the same way that we use images as backgrounds.
Set repeat gradient
background-image:repeating-linear-gradient(0deg, blue, green);
It was found that there was no repeated gradient effect after repeating-Linear-gradient () was set.
background-image:repeating-linear-gradient(0deg, blue, green 10%)
When we set green 10%, the gradient gradient starts from 0% to 10%, not filling the entire background, and starts repeating
background-image:repeating-linear-gradient(0deg, blue, green); background-size:100% 10%;
Background-size :100% 10%; To control the size of the fill background color. This can achieve the above effect.
Progress bar animation
Set the progress bar style and change background-position through animation to achieve dynamic effect. Because we set the repeating-Linear-gradient () function, even if the background starts backwards, it fills the whole element.
<div class="progress-outer">
<div class="progress-bg"></div>
</div>
Copy the code
.progress-outer{
background-color: rgba(180.160.120.2);
width:100%;
height: 20px;
border-radius: 20px;
}
.progress-bg{
background-image:repeating-linear-gradient(-45deg.#D9CFBB 25%.#C3B393 0.#C3B393 50%.#D9CFBB 0.#D9CFBB 75%.#C3B393 0);
width:60%;
height: 100%;
background-size:16px 16px;
border-radius: 20px;
animation: panoramic 5s linear forwards;
}
@keyframes panoramic{
to {
width:100%;
background-position: 160% 0; }}Copy the code
radial-gradient
define
The radial-gradient() CSS function creates an image that consists of a gradual transition between two or more colors emitted from the origin. Its shape can be circle or ellipse. This method returns an object of CSS data type, which isA kind of
Set the origin and shape, and the radial-gradient() function creates a transition effect for the corresponding shape.
grammar
radial-gradient(
[
[ circle || <length> ] [ at <position> ]? ,|
[ ellipse || [ <length> | <percentage> ]{2} ] [ at <position> ]?,|
at <position>,
]? <color-stop-list>
)
Copy the code
Look at the whole syntax structure, implementation see?
<position>
[
[ left | center | right ] || [ top | center | bottom ]
|
[ left | center | right | <length> | <percentage> ]
[ top | center | bottom | <length> | <percentage> ]?
|
[ [ left | right ] [ <length> | <percentage> ] ] &&
[ [ top | bottom ] [ <length> | <percentage> ] ]
]
Copy the code
Example:
/ / | | said before and after are independent, both are need to complete the [left | center | right] | | [top | center | bottom]Copy the code
Left Top, left Center…… Nine kinds of combination
[ left | center | right | <length> | <percentage> ]
[ top | center | bottom | <length> | <percentage> ]?
Copy the code
? Said can choose, can be a separate [left | center | | right < length > | < percentage >] of a value, also can be left in the top and left 10% 25 choice
[ [ left | right ] [ <length> | <percentage> ] ] &&
[ [ top | bottom ] [ <length> | <percentage> ] ]
Copy the code
- Right 10% bottom 30% left 10px top 30px
[ circle || <length> ] [ at <position> ]?
- background: radial-gradient(circle 50px at center, red, #b4a078,green)
[ ellipse || [ <length> | <percentage> ]{2} ] [ at <position> ]?
- background:radial-gradient(ellipse 50px 20px at center, transparent 20px, blue );
at <position>
The default shape is ellipse
Irregular card effect
background-image:radial-gradient( circle at center top,transparent 20px,blue 21px);
background-image:radial-gradient( circle at center top,transparent 20px,blue);
If we don’t set the end position after the end color, then the transition is between 20px and 100%, and we set the end of the transition at 21px to get a cut semicircle effect.
background-image:radial-gradient( circle at center top,blue 10px,transparent 11px); background-size:20px 15px; background-repeat:repeat-x; transform:rotate(180deg);
reference
You-need-to-know- CSS MDN 10 Demo examples Learn CSS3 radial-gradient