深入理解CSS线性渐变linear-gradient

前面的话

   在 CSS3 出现之前,渐变效果只能通过图形软件设计图片来实现,可拓展性差,还影响性能。如今已经进入 CSS3 标准的渐变可以很轻松的完成渐变效果。渐变实际上分为线性渐变和径向渐变两种,本文介绍线性渐变。

 

定义

  渐变实际上是两种或多种颜色之间的平滑过渡。而线性渐变是多种颜色沿着一条直线 (称为渐变线) 过渡。渐变的实现由两部分组成:渐变线和色标。渐变线用来控制发生渐变的方向;色标包含一个颜色值和一个位置,用来控制渐变的颜色变化。浏览器从每个色标的颜色淡出到下一个,以创建平滑的渐变,通过确定多个色标可以制作多色渐变效果。

  [注意]safari4-5、IOS3.2-4.3、android2.1-3 只支持线性渐变,且需要添加 -webkit-;safari5.1-6、IOS5.1-6.1、android4-4.3 支持线性和径向渐变,且需要添加 -webkit-;IE10+ 及其他高版本浏览器支持标准写法

<linear-gradient> = linear-gradient([[ <angle> | to <side-or-corner>] ,]? <color-stop>[, <color-stop>]+)
<side-or-corner> = [left | right] || [top | bottom]

 

渐变线

  渐变线从渐变框中心向两个方向进行拓展,起点和终点是渐变线与经过渐变框的一个角的垂直线的相交点

  渐变的第一个参数用于指定渐变线,默认是 to bottom。有两种方式指定渐变线方向

【1】使用角度

  0deg 表示沿着元素的中心线由下向上的方向 (类似于 y 轴),且正角度表示顺时针旋转

  [注意] 对于 -webkit- 旧版本浏览器,如 windows 系统下的 safari 浏览器来说,0deg 表示沿着元素中心线从左向右的方向 (类似于 x 轴),且正角度表示逆时针旋转

  所以 -webkit- 旧版本浏览器与标准浏览器的之间线性渐变的角度关系为

-webkit- 浏览器 = 90deg - 标准浏览器
相当于
-webkit-linear-gradient(90deg,red,blue) = linear-gradient(0deg,red,blue)

  [注意] 对于 webkit 内核的浏览器来说,使用 javascript 改变元素的样式。当带 -webkit- 的私有样式和不带 -webkit- 的标准样式同时存在的时候,并不一定是后面覆盖前面。所以如果两种写法产生的效果相同,但参数不同时,要使用浏览器识别来分别写不同的情况。

【2】使用关键字

to top -> 0deg
to right -> 90deg
to bottom -> 180deg
to left -> -90deg(或 270deg)
to top left -> -45deg(或 315deg)
to top right -> 45deg
to bottom left -> -135deg(或 225deg)
to bottom right -> 135deg

  [注意]window 系统的 safari 浏览器并不支持 'to' 加方向的关键字,如 to left。它只支持方向关键字,如 left。当然了 left 和 to left 方向是正好相反的

 

色标

  浏览器对于色标并没有默认值,且必须设置至少两个色标。色标由颜色和位置组成。颜色使用任何一种颜色模式都可以,而位置可以使用百分比或数值。

  [注意] 颜色的位置也可以设置负值

【1】必须是颜色在前,位置在后

//正确
background-image: linear-gradient(red 0%,blue 100%);
//错误
background-image: linear-gradient(0% red,100% blue);

【2】位置可以省略,浏览器默认会把第一个颜色的位置设置为 0%,把最后一个颜色的位置设置为 100%

background-image: linear-gradient(red 0%,blue 100%);
//等价于上一个
background-image: linear-gradient(red,blue);

【3】若渐变只有两种颜色,且第一个颜色的位置设置为 n%,第二个颜色的位置设置为 m%。则浏览器会将 0%-n% 的范围设置为第一个颜色的纯色,n%-m% 的范围设置为第一个颜色到第二个颜色的过渡,m%-100% 的范围设置为第二个颜色的纯色

background-image: linear-gradient(red 30%,blue 60%);
//等价于上一个
background-image: linear-gradient(red 0%,red 30%,blue 60%,blue 100%);

【4】若渐变颜色没有指定位置,则它们会均匀分布

background-image: linear-gradient(red,yellow,green,blue);

【5】若多色占据同一个位置,例 a、b、c 三色均占据 n% 这一位置,则 0%-n% 为前一种颜色与 a 颜色的颜色渐变;然后是 n%-n% 的 a 颜色与 c 颜色的颜色突变;n%-100% 是 c 颜色与后一种颜色的颜色渐变。因此,中间的 b 是无用的

background-image: linear-gradient(red,yellow 50%,white 50%,black 50%,blue);
//等价于上一个
background-image: linear-gradient(red,yellow 50%,black 50%,blue);

 

重复渐变

  重复渐变可以实现线性渐变的重复效果,使色标在渐变线方向上无限重复,实现一些特殊的效果

  [注意] 只有当首尾两颜色位置不在 0% 或 100% 时,重复渐变才生效

background-image: -webkit-repeating-linear-gradient(blue 20%,green 50%);
background-image: repeating-linear-gradient(blue 20%,green 50%);

纸张效果

  使用重复渐变可以实现横线纸张效果  

div{
    height: 200px;
    width:200px;
    font: 14px/20px '宋体';
    text-indent: 2em;
    background-image: -webkit-repeating-linear-gradient(#f9f9f9,#f9f9f9 9%,#ccc 10%);
    background-image: repeating-linear-gradient(#f9f9f9,#f9f9f9 9%,#ccc 10%);
}

 

多背景

  使用多背景属性,利用带有透明度的渐变颜色给图片添加渐变的透明效果

background: linear-gradient(rgba(255,255,255,0),rgba(255,255,255,0.8)),url('http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/img1.gif');

<style>
div{width: 200px;height: 200px;display: inline-block;}
.test1,.test2{background-image: linear-gradient(45deg,red 25%,transparent 25%),linear-gradient(-45deg,red 25%,transparent 25%),linear-gradient(45deg,transparent 75%,red 75%),linear-gradient(-45deg,transparent 75%,red 75%);}
.test2{
    background-size: 20% 20%;
}    
</style>
<div class="test1"></div>    
<div class="test2"></div>

 

应用场景

  在 CSS 样式中,渐变相当于背景图片,在理论上可在任何使用 url() 值的地方采用。比如最常见的 background-image、list-style-image 以及 border-image。但目前为止,仅在背景图片中得到完美的支持

【1】background-image

background-image: -webkit-linear-gradient(pink,lightblue,lightgreen);
background-image: linear-gradient(pink,lightblue,lightgreen);

  [注意] 渐变框的大小由background-size决定,默认是 padding box

【2】list-style-image

list-style-image: -webkit-linear-gradient(red,blue);
list-style-image: linear-gradient(red,blue);
font-size: 50px;

  [注意] 渐变框的大小由 font-size 决定,默认是 1em 

  [注意]firefox 不支持在 list-style-image 中设置

【3】border-image

-webkit-border-image:  -webkit-linear-gradient(black,green) 1/10px;    
border-image:  linear-gradient(black,green) 1/10px;

  [注意] 渐变框的大小由 borer-width 决定,safari 浏览器始终实现的都是带有 fill 参数的表现

 

IE 兼容

  IE9- 浏览器并不支持该属性,但可以使用 IE 准专有的滤镜语法来实现兼容

filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='#color', endColorstr='#color');
GradientType 代表渐变线方向,0 为垂直 (默认),1 为水平
#color 代表色标,格式是 #aarrggbb,其中 aa 为透明度,rrggbb 为 rgb 模式的颜色
startColorstr 的默认值是 #ff0000ff 
endColorstr 的默认值是 #ff000000

  [注意] 由于 IE 滤镜只支持首尾两个位置,且方向只可以为垂直和水平,所以有很大的局限性

filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='#ff0000ff', endColorstr='#ffff00ff');