浅析CSS中怎么实现线性渐变(linear-gradient)

 3636

CSS中怎么实现线性渐变?下面本篇文章给大家介绍一下CSS线性渐变函数linear-gradient()的使用方法,并聊聊线性渐变的多种应用,希望对大家有所帮助!


浅析CSS中怎么实现线性渐变(linear-gradient)


linear-gradient

1. 语法

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

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

这2种在使用方式和表现形式上都有所不同,使用direction时,前者要带to, 后者不带;使用angle时,表现不一致。


1)默认

二者默认都是从上到下

  1. background-image:linear-gradient(#00ffff, #ff1493, #006699);
  2. background-image:-webkit-linear-gradient(#00ffff, #ff1493, #006699)

浅析CSS中怎么实现线性渐变(linear-gradient)

2)<direction>: [left|right]|[top|bottom]的使用

二者表现方向相反

  1. background-image:linear-gradient(to left, #00ffff, #ff1493, #006699);
  2. background-image:-webkit-linear-gradient(left, #00ffff, #ff1493, #006699);

浅析CSS中怎么实现线性渐变(linear-gradient)

  1. background-image:linear-gradient(to left top, #00ffff, #ff1493, #006699);
  2. background-image:-webkit-linear-gradient(left top, #00ffff, #ff1493, #006699);

浅析CSS中怎么实现线性渐变(linear-gradient)

3)<angle>的使用

度数方向的对应关系。-webkit-与之对应的方向则为450°-angle


浅析CSS中怎么实现线性渐变(linear-gradient)

  1. background-image:linear-gradient(275deg, #ff1493, #000000, #006699);
  2. background-image:-webkit-linear-gradient(175deg, #ff1493, #000000, #006699);

450°-175°=275°,所以二者表现一致,如下图:

浅析CSS中怎么实现线性渐变(linear-gradient)

4)<color stop> = <color [percentage|length]>的使用

stop可使用百分比,也可以使用具体值,表示这种颜色在此位置达到饱和

  1. background-image:linear-gradient(to right, #ff1493 10%, #000000 40%, #006699 60%);
  2. background-image:-webkit-linear-gradient(to right, #ff1493 10%, #000000 40%, #006699 60%);

浅析CSS中怎么实现线性渐变(linear-gradient)

从上图可以看出颜色变化过程:

0% --> 10%: #ff1493一直处于饱和

10% --> 40%: #ff1493渐变为#000000, 在40%处,#000000达到饱和

40% --> 60%: #000000渐变为#006699, 在60%处,#006699达到饱和

60% --> 100%: #006699一直处于饱和

利用这一特性,可以绘制出条纹

  1. background-image:linear-gradient(to right, #ff1493 33%, #000000 33%, #000000 66%, #006699 66%);
  2. background-image:-webkit-linear-gradient(to right, #ff1493 33%, #000000 33%, #000000 66%, #006699 66%);

浅析CSS中怎么实现线性渐变(linear-gradient)

注: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显示,效果如下图:

  1. background-image:linear-gradient(right, #ff1493 60px, #000000 20px);
  2. background-image:-webkit-linear-gradient(right, #ff1493 60px, #000000 20px);

浅析CSS中怎么实现线性渐变(linear-gradient)

扩展1:渐变中心

默认是2种颜色的中心,但是我们可以设置其渐变中心

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

注:-webkit-linear-gradient不支持此用法

浅析CSS中怎么实现线性渐变(linear-gradient)

扩展2: repeating-linear-gradient

我们可以使用属性这个绘制重复的色块

  1. background-image:repeating-linear-gradient(0deg, #ff1493, #000000 10px, #006699 20px);
  2. background-image:-webkit-repeating-linear-gradient(0deg, #ff1493, #000000 10px, #006699 20px)

浅析CSS中怎么实现线性渐变(linear-gradient)

2、常用样式

(1)多色星空

  1. background-image:
  2.     linear-gradient(45deg, rgba(255, 0, 76, 0.7), rgba(0, 0, 255, 0) 80%),
  3.     linear-gradient(135deg, rgba(106, 0, 128, 1), rgba(0, 128, 0, 0) 80%),
  4.     linear-gradient(225deg, rgba(0, 255, 255, 1), rgba(0, 255, 255, 0) 80%),
  5.     linear-gradient(315deg, rgba(255, 192, 203, 0.7), rgba(255, 192, 203, 0) 80%);

同时设置多个值,让整个背景色看起来比较绚丽

浅析CSS中怎么实现线性渐变(linear-gradient)

(2)格子图案

  1. background-image:
  2.     repeating-linear-gradient(0deg, rgba(0, 255, 255, 0.3) 0px 5px, transparent 5px 10px),
  3.     repeating-linear-gradient(90deg, rgba(0, 255, 255, 0.3) 0px 5px, transparent 5px 10px);
  4.      
  5. background-image:
  6.     repeating-linear-gradient(45deg, rgba(0, 255, 255, 0.3) 0px 5px, transparent 5px 10px),
  7.     repeating-linear-gradient(135deg, rgba(0, 255, 255, 0.3) 0px 5px, transparent 5px 10px);

利用颜色与透明色交替渲染

浅析CSS中怎么实现线性渐变(linear-gradient)

(3)边框渐变

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

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

浅析CSS中怎么实现线性渐变(linear-gradient)

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

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

浅析CSS中怎么实现线性渐变(linear-gradient)

  1. <div id="wrap">
  2.     <div id="content"></div>
  3. </div>
  4. <style>
  5. #wrap {
  6.     width: 180px;
  7.     height: 40px;
  8.     border-radius: 20px;
  9.     background: #FFF;
  10.     position: relative;
  11. }
  12.  
  13. #wrap::before {
  14.     content: '';
  15.     position: absolute;
  16.     left: -5px;
  17.     right: -5px;
  18.     top: -5px;
  19.     bottom: -5px;
  20.     background-image: linear-gradient(45deg, aqua, pink, purple);
  21.     border-radius: 25px;
  22.     z-index: -1
  23. }
  24.  
  25. /*或者*/
  26.  
  27. #wrap {
  28.     width: 180px;
  29.     height: 40px;
  30.     border-radius: 20px;
  31.     background: #FFF;
  32.     position: relative;
  33.     border: 5px solid transparent;
  34.     background-origin: border-box;
  35.     background-image: linear-gradient(#FFF, #FFF), linear-gradient(45deg, aqua, pink, purple);
  36.     background-clip: padding-box, border-box;
  37. }
  38.  
  39. /*或者*/
  40.  
  41. #wrap {
  42.     width: 180px;
  43.     height: 50px;
  44.     border: 5px solid transparent;
  45.     border-radius: 25px;
  46.     background-image: linear-gradient(45deg, aqua, pink, purple);
  47.     background-origin: border-box;
  48. }
  49.  
  50. #content {
  51.     width: 100%;
  52.     height: 100%;
  53.     border-radius: 20px;
  54.     background: #FFF;
  55. }
  56.  
  57. </style>

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

浅析CSS中怎么实现线性渐变(linear-gradient)

(4)文字渐变

  1. <div id="wrap"> Darker CMJ</div>
  2. <style>
  3. #wrap {
  4.     font-size: 40px;
  5.     line-height: 40px;
  6.     font-weight: bold;
  7.     background-clip: text;
  8.     -webkit-background-clip: text;
  9.     // color: transparent;
  10.     -webkit-text-fill-color: transparent;
  11.     background-image: linear-gradient(45deg, aqua, pink, purple);
  12. }
  13. </style>

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

浅析CSS中怎么实现线性渐变(linear-gradient)

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

TAG标签:
本文网址:https://www.zztuku.com/detail-11457.html
站长图库 - 浅析CSS中怎么实现线性渐变(linear-gradient)
申明:本文转载于《掘金社区》,如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐