Maison > Article > interface Web > Une brève analyse de la façon d'implémenter un dégradé linéaire (gradient linéaire) en CSS
Comment implémenter un dégradé linéaire en CSS ? L'article suivant vous présentera comment utiliser la fonction de dégradé linéaire CSS Linear-gradient() et parlera des différentes applications des dégradés linéaires. J'espère qu'il sera utile à tout le monde !
1. Syntaxe
gradient-linéaire([[vers <direction>|<angle>],]? <arr de couleur>, <arr de couleur>[, ...]?)</arr></arr></angle></direction>
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>
这2种在使用方式和表现形式上都有所不同,使用direction
时,前者要带to
, 后者不带;使用angle
时,表现不一致。【推荐学习:css视频教程】
1)默认
二者默认都是从上到下
background-image:linear-gradient(#00ffff, #ff1493, #006699); background-image:-webkit-linear-gradient(#00ffff, #ff1493, #006699)
2)<direction>: [left|right]|[top|bottom]</direction>
的使用
二者表现方向相反
background-image:linear-gradient(to left, #00ffff, #ff1493, #006699); background-image:-webkit-linear-gradient(left, #00ffff, #ff1493, #006699);
background-image:linear-gradient(to left top, #00ffff, #ff1493, #006699); background-image:-webkit-linear-gradient(left top, #00ffff, #ff1493, #006699);
3)<angle></angle>
的使用
度数
与方向
的对应关系。-webkit-
与之对应的方向则为450°-angle
background-image:linear-gradient(275deg, #ff1493, #000000, #006699); background-image:-webkit-linear-gradient(175deg, #ff1493, #000000, #006699);
450°-175°=275°
,所以二者表现一致,如下图:
4)<color stop> = <color></color></color>
的使用
stop
可使用百分比,也可以使用具体值,表示这种颜色在此位置达到饱和
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%);
从上图可以看出颜色变化过程:
0% --> 10%: #ff1493
一直处于饱和
10% --> 40%: #ff1493
渐变为#000000
, 在40%
处,#000000
达到饱和
40% --> 60%: #000000
渐变为#006699
, 在60%
处,#006699
达到饱和
60% --> 100%: #006699
一直处于饱和
利用这一特性,可以绘制出条纹
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%);
注:stop
还可以同时设置2个值, 如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%);
,效果与上图一致。
若后者的值小于前者,以前者为准,如下20px
小于60px
,实际按60px
显示,效果如下图:
background-image:linear-gradient(right, #ff1493 60px, #000000 20px); background-image:-webkit-linear-gradient(right, #ff1493 60px, #000000 20px);
扩展1:渐变中心
默认是2种颜色的中心,但是我们可以设置其渐变中心
/* 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);
注:-webkit-linear-gradient
-webkit-linear-gradient([[<direction>|<angle>],]? <arr de couleur>, <color stop>[, ...]?)</color></arr></angle></direction>
Ces deux sont différents dans leur utilisation et leur expression. Lors de l'utilisation de direction
, le premier nécessite
1) Par défaut
Les deux valeurs par défaut sont de haut en basbackground-image:repeating-linear-gradient(0deg, #ff1493, #000000 10px, #006699 20px); background-image:-webkit-repeating-linear-gradient(0deg, #ff1493, #000000 10px, #006699 20px)
2)<direction> : [gauche|droite]|[haut|bas] Le utilisation de </direction>
Les deux directions de performance sont opposées
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%);
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);
<angle></angle>
La correspondance entre le degré
et la direction relation. <code>-webkit-
La direction correspondante est un angle de 450°
<div id="wrap"></div> <style> #wrap { width: 180px; height: 40px; border: 5px solid transparent; border-image: linear-gradient(45deg, aqua, pink, purple) 1; } </style>
450°-175°=275°
, donc les deux se comportent de la même manière, comme indiqué ci-dessous :
4) L'utilisation de
<color stop> = <color></color></color>
🎜🎜🎜stop
peut utiliser des pourcentages ou des valeurs spécifiques, indiquant que cela la couleur est saturée
à cette position🎜<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>🎜🎜🎜Vous pouvez voir le processus de changement de couleur sur l'image ci-dessus : 🎜🎜
0% --> 10% : #ff1493
a été dans Saturation🎜🎜10% --> 40% : #ff1493
passe à #000000
, à 40%
, #000000 atteint la saturation
🎜🎜40% --> 60% : #000000
dégradé à #006699
, à 60 %
, #006699
atteint la saturation
🎜🎜60 % --> : #006699
Toujours présent saturé
🎜🎜En utilisant cette fonctionnalité, vous pouvez dessiner des rayures🎜<div id="wrap"> <div id="content"></div> </div> <style> #wrap { width: 180px; height: 40px; border-radius: 20px; background: #FFF; position: relative; } #wrap::before { content: ''; 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>🎜🎜🎜Remarque :
stop
peut également définir 2 valeurs en même temps, telles que linéaire- dégradé (à droite, #ff1493 0% 33%, #000000 33% 66%, #006699 66% 100%);-webkit-linear-gradient(à droite, #ff1493 33%, #000000 33% 66%, # 006699 66% 100%);
, l'effet est conforme à l'image ci-dessus. 🎜🎜🎜Si cette dernière valeur est inférieure à la première, la première prévaudra. Si 20px
est inférieur à 60px
, la valeur réelle sera affichée sous la forme 60px.
. L'effet est le suivant :🎜<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>🎜🎜 🎜🎜Extension 1 : Centre du dégradé 🎜🎜🎜La valeur par défaut est le centre de 2 couleurs, mais on peut définir son centre du dégradé 🎜rrreee🎜Remarque :
-webkit -linear-gradient
ne prend pas en charge cette utilisation 🎜🎜🎜🎜🎜🎜🎜Extension 2 : répéter-linear-gradient🎜🎜🎜Nous pouvons utiliser l'attribut pour dessiner des blocs de couleur répétés🎜rrreee🎜🎜🎜🎜🎜🎜2 .Styles courants 🎜🎜🎜🎜🎜 (1) Ciel étoilé multicolore🎜🎜rrreee🎜Définissez plusieurs valeurs en même temps pour rendre toute la couleur d'arrière-plan plus magnifique🎜🎜🎜🎜🎜🎜 (2) Motif à carreaux🎜 🎜rrreee🎜Utilisez la couleur et la couleur transparente pour rendre alternativement🎜🎜🎜🎜(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>
内部背景透明,但是不支持设置border-radius
<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>
注:可以使用clip-path
裁剪出圆角, 但是这种方式不适用于角度较大的圆角
<div id="wrap"> <div id="content"></div> </div> <style> #wrap { width: 180px; height: 40px; border-radius: 20px; background: #FFF; position: relative; } #wrap::before { content: ''; 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>
这几种方式都能做到圆角渐变边框,但是无法做到内部背景透明
(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>
background-clip
规定背景的绘制区域,我们设置其值为text
,就是在文字区域绘制,然后将文字color
或者-webkit-text-fill-color
设置为透明色,渐变区域就能显示出来了
好了,over,第一次写文章,希望能坚持下去=.=
(学习视频分享:web前端)
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!