Maison  >  Article  >  interface Web  >  Partage d'exemples d'introduction de dégradé linéaire CSS3

Partage d'exemples d'introduction de dégradé linéaire CSS3

小云云
小云云original
2018-01-23 10:51:152923parcourir

Le dégradé est présenté sur la page sous la forme d'une image d'arrière-plan L'essence du dégradé est l'image d'arrière-plan. En CSS3, les dégradés peuvent être divisés en dégradé linéaire et dégradé radial. Un dégradé linéaire est un dégradé le long d'une ligne de dégradé, tandis qu'un dégradé radial est un dégradé autour d'une ellipse ou d'un cercle.

2. Dégradé linéaire dégradé linéaire

2.1 Syntaxe de base

image d'arrière-plan : dégradé linéaire ([ | ,]? [, ]+ );

[] est une classe de caractères dans les expressions régulières et peut être comprise ici comme une petite unité ; 🎜>| signifie ou, soit choisir le recto ou le verso

? Cela signifie 0 ou 1 sens. Autrement dit, si vous ne spécifiez pas la direction, vous pouvez utiliser directement la couleur du dégradé ;

+ le signe plus signifie 1 ou plus.

2.1.1 Angle

Question : Si l'angle est de 45 degrés et que la couleur du dégradé passe de l'encre foncée au jaune, laquelle des images suivantes est correcte ?

<p></p>

Partage d'exemples d'introduction de dégradé linéaire CSS3Réponse correcte :

B

Cette compréhension est quelque peu différente de la rotation CSS3 familière d'un certain angle, par exemple, The L'effet d'une rotation de 90 degrés en CSS3 est le suivant :

<p></p>

Partage d'exemples d'introduction de dégradé linéaire CSS3 Dans les dégradés linéaires, l'angle du dégradé est par défaut une rotation dans le sens des aiguilles d'une montre de bas en haut dans la direction verticale. peut le comprendre comme le sens de rotation de l'aiguille de l'horloge, comme le montre la figure suivante :

<p></p>

Partage d'exemples d'introduction de dégradé linéaire CSS3L'angle du dégradé indique la direction du gradient linéaire, 0deg signifie le gradient de de haut en bas ; 90 degrés signifie un dégradé de gauche à droite ; 180 degrés signifie un dégradé de bas en haut ; 270 degrés signifie un dégradé de droite à gauche ; L'effet d'angle du dégradé est comme indiqué sur la figure :

<p></p>

Partage d'exemples d'introduction de dégradé linéaire CSS3Dans l'exemple ci-dessus, l'effet de 0deg->360deg est en fait une rotation dans le sens des aiguilles d'une montre.

2.1.2 côté ou coin

La signification chinoise de côté ou coin signifie côté ou coin. Les valeurs facultatives dans le sens vertical sont : top , center , bottom et les valeurs facultatives dans le sens horizontal sont left , center et right . La valeur par défaut est

center bottom

, ce qui signifie dégradé de haut en bas. peut être utilisé en combinaison avec les mots-clés to + side-or-corner. Si to n'est pas ajouté, cela indique le point de départ du dégradé. L'ajout de to indique la direction du dégradé . Par exemple : en haut équivaut à 0 deg, à droite équivaut à 90 deg, en bas équivaut à 180 deg, à gauche équivaut à 270 deg. Les effets pertinents sont présentés dans la figure ci-dessous :

Partage d'exemples d'introduction de dégradé linéaire CSS3Remarque pour une utilisation dans différentes versions de navigateurs :

<p></p>
    Nouvelles versions de les navigateurs peuvent utiliser directement la syntaxe standard du w3c, les navigateurs de version inférieure doivent utiliser chaque préfixe de navigateur
  • <p></p>
  • IE10 ou inférieur ne prend pas en charge les dégradés ; Les nouvelles versions de Chrome et Firefox ont Le préfixe privé est supprimé, et la direction est différente entre l'ajout du préfixe privé et la non-ajout du préfixe privé (si le préfixe privé est ajouté, la droite est 0deg, puis tourne dans le sens inverse des aiguilles d'une montre );
  • <p></p>
  • oper Pris en charge à partir de 37, il n'y a pas de préfixe privé, et il sera ignoré s'il est ajouté
  • <p></p>
  • Cet article expliquera ; le dégradé linéaire dégradé linéaire dans la syntaxe standard du W3C et le dégradé radial radial-gradient seront expliqués dans le prochain article. L'article présente
  • 2.1.3 color-stop

  • [ | ]

spécifie la couleur, le point de départ et la fin. Traduit en chinois : couleur + espace + pourcentage ou valeur de longueur.

<p></p> <p></p> <p></p>
background: linear-gradient(#fb3 20%, #58a 80%);
Maintenant, les 20 % supérieurs de la zone sont remplis de couleur unie #fb3, et les 20 % inférieurs de la zone sont remplis avec #58a Couleur unie, la véritable zone de dégradé se situe entre 20% et 80% de la hauteur. Si vous rapprochez deux échelles de couleurs, superposez les deux échelles de couleurs : <p></p>

Partage d'exemples d'introduction de dégradé linéaire CSS3

<p></p>
background: linear-gradient(#fb3 50%, #58a 50%);
" Si plusieurs échelles de couleurs ont la même position, elles produira une zone de transition infiniment petite, et les couleurs de début et de fin de la transition sont les première et dernière valeurs spécifiées. À partir de l'effet, la couleur changera soudainement à cette position, plutôt qu'un processus de dégradé fluide. 🎜> - Images CSS (troisième édition) ( http://w3.org/TR/css3-images ) <p></p>Parce qu'un dégradé est une image générée par du code, nous pouvons le traiter comme n'importe quelle autre image d'arrière-plan et redimensionnez-le via background-size :

Partage d'exemples d'introduction de dégradé linéaire CSS3

<p></p>

<p></p>
<p></p>

S'il s'agit d'une bande verticale, le code et l'effet sont les suivants :

.box{
  width: 200px;
  height: 90px;
  background: linear-gradient(#fb3 50%, #58a 50%);
  background-size: 100% 30px;
}

Partage d'exemples d'introduction de dégradé linéaire CSS3

Partage d'exemples d'introduction de dégradé linéaire CSS3

为了避免每次改动条纹宽度时都要修改两个数字,我们可以再次从规范那里找到捷径。

“如果某个色标的位置值比整个列表中在它之前的色标的位置值都要小,则该色标的位置值会被设置为它前面所有色标位置值的最大值。”

——CSS 图像(第三版)( http://w3.org/TR/css3-images )

对于水平和垂直渐变条纹我们很好理解。如果是斜向渐变,我们想得到条纹的宽度为15px,我们可以这样写:

<p></p>

 

.box{
  width: 200px;
  height: 100px;
  background: linear-gradient(45deg,
    #fb3 25%, #58a 0, #58a 50%,
    #fb3 0, #fb3 75%, #58a 0);
  background-size: 30px 30px;
}

 

Partage d'exemples d'introduction de dégradé linéaire CSS3

对比想要的图以及实际效果图,为什么得到线条的宽度比我们想要的线条宽度要小,难道是浏览器出问题了,no,是我们自己错了。这就需要深入理解渐变的长度了。

2.2 线性渐变的渐变长度的理解

如何确定渐变线的长度?我们可以从官网的解释中找到答案:

Partage d'exemples d'introduction de dégradé linéaire CSS3

渐变线是过渐变区域中心的一条直线,而渐变的起点和终点是在与渐变线的垂直线上。如果给定渐变的区域和渐变的方向,我们就能够确定渐变的起始点和总长度了。因此在下面的css样式中:

.box{
  width: 200px;
  height: 100px;
  background: linear-gradient(45deg, #fb3 25%, #58a 0, #58a 50%, #fb3 0, #fb3 75%, #58a 0);
  background-size: 30px 30px;
}

 

我们可以用下面的这幅图来计算渐变的长度,我们指定了区域的大小时30px,根据 勾股定理 ,可以计算直角三角形的斜边长度。因此,我们计算得到的条纹的宽度实际是: 15/1.414=10.606 ,比我们需要的宽度15p要小。

$$ 15/√2 $$

Partage d'exemples d'introduction de dégradé linéaire CSS3

这就意味着,如果想要让条纹的宽度变化为我们原本想要的15px,就需要将 background-size 指定为 2*15*1.4=42.426px 。

Partage d'exemples d'introduction de dégradé linéaire CSS3

我们来看下修改后的效果,修改 background-size 后,得到了我们想要的效果图。

2.3 线性渐变的案例

2.3.1 利用线性渐变生成条纹

在上面的例子中,我们已经使用线性渐变生成了水平和垂直条纹,这里就不在赘述。

2.3.2 利用线性渐变生成多背景图片

在CSS3中,backgrounds支持多背景,越前面的背景越处于上面 ,也就是背景可以无限累加,而 渐变的本质是background-image ,所以我们可以实现任意数量的渐变背景图的叠加效果。

有如下图片:

Partage d'exemples d'introduction de dégradé linéaire CSS3

我们添加透明值: linear-gradient(to bottom left, #fc3, rgba(255,255,255,0))

.demo{
  width: 250px;
  height: 156px;
  background: linear-gradient(to bottom left, #fc3, rgba(255,255,255,0)), url(./flower.jpg);
}

 

得到的效果如下:

Partage d'exemples d'introduction de dégradé linéaire CSS3

我们可以利用这一点,来给背景添加不同的效果,如让图片不可见(修改为: linear-gradient(to bottom left, #fff, rgba(255,255,255,0)) )。

2.3.3 利用线性渐变生成比例可控的虚线

在实际开发中,如果需要虚线,我们一般会设置 border-style:dashed ,然而这种方法存在一个问题: 实线和虚线的比例是一定的 。在Chrome和Firefox浏览器下,颜色区的宽高比是 3:1 ,颜色和透明区的宽度比例是 1:1 :

Partage d'exemples d'introduction de dégradé linéaire CSS3

而在IE浏览器下,颜色区的宽高比是 2:1 ,颜色区和透明区的宽度比例也是 2:1 :

Partage d'exemples d'introduction de dégradé linéaire CSS3

如果设计师设计的UI中,要求虚线的颜色区的宽高比是 5:3 ,实线与虚线的比例是 1:1 ,此时使用 border-style:dashed 就达不到设计师设计的效果了。有两种方法可以解决这个问题:

  • 要求设计师改UI,这么low X的事难道是我们前端工程师做的吗?

  • 查阅资料,使用其他方法实现设计师想要的效果,正确选择!

这里,我们就可以使用 linear-gradient 到达设计师想要的效果:

.demo{
  height: 3px;
  background: linear-gradient(to right, #000, #000 5px, transparent 5px, transparent);
  background-size: 10px 100%;
}

 

对应的效果如下:

Partage d'exemples d'introduction de dégradé linéaire CSS3

2.3.4 利用线性渐变生成带线框的三角

考虑下面的场景,我们需要生成一个对话框:

Partage d'exemples d'introduction de dégradé linéaire CSS3

我们可能绝大多数使用下面的做法:

.talk {
  display: inline-block;
  max-width: 80%;
  border: 1px solid blue;
  border-radius: 3px;
  padding: 6px 10px;
  font-size: 14px;
  position: relative;
}

 

.talk:before {
  content: '';
  position: absolute;
  width: 6px;
  height: 6px;
  border: 1px solid blue;
  border-right: 0;
  border-bottom: 0;
  left: -4px;
  top: 13px;
  transform: rotate(-45deg);
  background-color: #fff;
}

 

如果背景不是白色:

.talk {
  display: inline-block;
  max-width: 80%;
  border: 1px solid blue;
  border-radius: 3px;
  padding: 6px 10px;
  background: linear-gradient(to right, deeppink, yellow);
  font-size: 14px;
  position: relative;
}

 

Partage d'exemples d'introduction de dégradé linéaire CSS3

可以看到如果背景色不是白色,旋转后的效果就有一个多余的三角形,不是我们想要的效果,我们可能尝试这样修改css代码:

.talk:before {
   content: '';
   position: absolute;
   display: inline-block;
   width: 0;
   height: 0;
   border-top: 5px solid transparent;
   border-right: 5px solid blue;
   border-bottom: 5px solid transparent;
   left: -5.1px;
   top: 12px;
}

 

Partage d'exemples d'introduction de dégradé linéaire CSS3

额,比上面的效果好多了,但是三角与边框交接的区域多了一个线条,与我们想要的效果还是有出入,此时我们使用线性渐变看看,如下css所示:

.talk:before {
  content: "";
  position: absolute;
  width: 6px;
  height: 6px;
  background: linear-gradient(to top, blue, blue) no-repeat,
              linear-gradient(to right, blue, blue) no-repeat,
              linear-gradient(135deg, #fff, #fff 5.2px, hsla(0, 0%, 100%, 0) 5.2px) no-repeat;
  background-size: 60px 1px, 1px 60px, 60px 60px;       
  transform: rotate(-45deg);
  left: -4px;
  top: 13px;
}

 

Partage d'exemples d'introduction de dégradé linéaire CSS3

哇,看起来不错额,今晚可以和妹子约起了。。。 Partage d'exemples d'introduction de dégradé linéaire CSS3

2.3.5 利用线性渐变生成加号和减号

考虑有以下需求:

Partage d'exemples d'introduction de dégradé linéaire CSS3

  1. 切图,使用小图片;

  2. 传统方法,使用 ::before 和 ::after 伪元素配合实现;

  3. 使用线性渐变实现;

<a></a>
<a></a>

 

传统方法:

.btn {
  display: inline-block;
  background: #f0f0f0 no-repeat center;
  border: 1px solid #d0d0d0;
  width: 24px;
  height: 24px;
  border-radius: 2px;
  color: #666;
  transition: color .2s;
}
.btn-plus{
  position: relative;
}

.btn-plus:before{
  content: '';
  position: absolute;
  width: 10px;
  height: 2px;
  background-color: currentColor;
  left: 50%;
  top: 50%;
  margin-top: -1px;
  margin-left: -5px;
}
.btn-plus:after{
  content: '';
  position: absolute;
  width: 2px;
  height: 10px;
  background-color: currentColor;
  left: 50%;
  top: 50%;
  margin-top: -5px;
  margin-left: -1px;
}

 

使用线性渐变方法:

.btn {
  display: inline-block;
  background: #f0f0f0 no-repeat center;
  border: 1px solid #d0d0d0;
  width: 24px;
  height: 24px;
  border-radius: 2px;
  color: #666;
  transition: color .2s;
}
.btn-plus {
  background-image: 
    linear-gradient(to top, currentColor, currentColor), 
    linear-gradient(to top, currentColor, currentColor);
  background-size: 10px 2px, 2px 10px;
}

.btn-minus {
  background-image: linear-gradient(to top, currentColor, currentColor);
  background-size: 10px 2px;
}

 

Partage dexemples dintroduction de dégradé linéaire CSS3

这种方法生成加号和等号与传统使用 ::before 和 ::after 以及配合 background-color 和 border 相比,使用渐变背景生成的好处是居中定位方便。

2.3.6 利用线性渐变生成切角效果

直接看代码:

<p></p>

 

.clip{
  width: 150px;
  height: 150px;
  background: #58a;
  background:
    linear-gradient(135deg, transparent 15px, deeppink 0)
    top left,
    linear-gradient(-135deg, transparent 15px, yellow 0)
    top right,
    linear-gradient(-45deg, transparent 15px, blue 0)
    bottom right,
    linear-gradient(45deg, transparent 15px, green 0)
    bottom left;
  background-size: 50% 50%;
  background-repeat: no-repeat;
}

 

Partage d'exemples d'introduction de dégradé linéaire CSS3

利用线性渐变还可以实现折角效果(计算稍微复杂,详细计算步骤可以看《css揭秘》相关章节),如:

Partage d'exemples d'introduction de dégradé linéaire CSS3

2.3.7 利用线性渐变实现信封效果

<p>重复渐变实现信封效果</p>

 

.demo2{
   width: 300px;
   font-size: 18px;
   padding: 10px;
   border: 10px solid transparent;
   background: linear-gradient(white, white) padding-box,
     repeating-linear-gradient(-45deg, red 0, red 12.5%, transparent 0, transparent 25%,
       #58a 0, #58a 37.5%, transparent 0, transparent 50%) 0 / 60px 60px;
}

 

Partage d'exemples d'introduction de dégradé linéaire CSS3

2.3.8 利用线性渐变实现裁剪效果

<p>这里是文字</p>

 

.clip{
  padding: 1em;
  border: 10px solid transparent;
  background: linear-gradient(white, white) padding-box,
    repeating-linear-gradient(-45deg, black 0, black 25%, transparent 0, transparent 50%) 0 / 10px 10px;
  animation: ants 12s linear infinite;
  max-width: 20em;
}

@keyframes ants {
  from { background-position: 0 0; }
  to { background-position: 100% 100%; }
}

 

在浏览器中的效果如下:

Partage d'exemples d'introduction de dégradé linéaire CSS3

如果将 boder 修改为 1px solid transparent ,可以看到下面的效果:

Partage d'exemples d'introduction de dégradé linéaire CSS3

2.4 更多线性渐变的应用

更多关于线性渐变的应用可以查看 这里

这里的图形都是使用线性渐变实现的,可见CSS3中线性渐变功能之强大!

Partage d'exemples d'introduction de dégradé linéaire CSS3

4 更多关于线性渐变的东西

除了线性渐变 linear-gradient ,css3中还支持重复线性渐变 reapting-linear-gradient 。

  • 利用重复线性渐变实现斜向条纹的效果,与线性渐变相比,不需要苦苦思考生成一个重复单元,直接改变渐变的角度以及尺寸即可。

    background: repeating-linear-gradient(60deg,#fb3, #fb3 15px, #58a 0, #58a 30px);

Partage d'exemples d'introduction de dégradé linéaire CSS3

5 写在最后

如果想对提高自己的csss水平,推荐《CSS揭秘》,很不错额。

Partage d'exemples d'introduction de dégradé linéaire CSS3

感谢阅读,希望能帮助到你。

相关推荐:

javascript计算渐变颜色的实例

html5 canvas绘制放射性渐变色效果代码实例

实例详解css3编写浏览器渐变背景色的方法

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn