爱程序网

linear-gradient 的“高能”用法

来源: 阅读:

首先,让我们来了解一下“linear-gradient”的基本用法:

说明:用线性渐变创建图像

语法:

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

<side-or-corner> = [left | right] || [top | bottom]

<color-stop> = <color> [ <length> | <percentage> ]?

取值:

下述值用来表示渐变的方向,可以使用角度或者关键字来设置:

<angle>:用角度值指定渐变的方向(或角度)。

to left:设置渐变为从右到左。相当于: 270deg

to right:设置渐变从左到右。相当于: 90deg

to top:设置渐变从下到上。相当于: 0deg

to bottom:设置渐变从上到下。相当于: 180deg。这是默认值,等同于留空不写。

<color-stop>:用于指定渐变的起止颜色:

<color>:指定颜色。

<length>:用长度值指定起止色位置。不允许负值

<percentage>:用百分比指定起止色位置。

其他知识点:

不知你是否注意到“第一个”语法后面的“+”号没,这些符号(“?”、“+”、“*”)其实用法跟正则表达式很像,如果正则表达式不知道的请看下面正解:

  ,:代表每个属性之间的分隔符号。

  ?:代表“属性”可以出现零次或一次,也就是可有可无

  +:代表“属性”可以出现一次或多次,但是必须出现一次

  *:代表“属性”可以出现零次或多次。

  |:代表可以从多个“属性”中任选一个。

  ||:代表“属性”可以是左边的一个或是右边的一个,或是两个都行

  []:代表里面是“属性”或“属性”集合

  <>:这个不是正则表达式里面的,但是它代表定义的取值范围,如上语法的“<angle>”,取值的里面就会附带说明这个“<angle>”是干嘛的

  {1,4}:代表“属性”最少出现一次,最多出现四次。“1”和“4”都是动态的值,不是固定的,根据描述而定

 

来看看基本用法实例:

  

  (图1)

  linear-gradient(#fff, #333);

  linear-gradient(to bottom, #fff, #333);

  linear-gradient(to top, #333, #fff);

  linear-gradient(180deg, #fff, #333);

  linear-gradient(to bottom, #fff 0%, #333 100%);

  以上这五句样式都可以实现(图1)的渐变效果

 

再来看看复杂点的普通实例:

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4   <meta charset="utf-8" />
 5   <title></title>
 6   <style>
 7     div { width: 200px; height: 100px; margin-top: 10px; border: 1px solid #ddd;}
 8     .test { background: linear-gradient(#fff, #333);}
 9     .test2 { background: linear-gradient(#000, #f00 50%, #090);}
10     .test3 { background: linear-gradient(0deg, #000 20%, #f00 50%, #090 80%);}
11     .test4 { background: linear-gradient(45deg, #000, #f00 50%, #090);}
12     .test5 { background: linear-gradient(to top right, #000, #f00 50%, #090);}
13   </style>
14 </head>
15 <body>
16   <div class="test"></div>
17   <div class="test2"></div>
18   <div class="test3"></div>
19   <div class="test4"></div>
20   <div class="test5"></div>
21 </body>
22 </html>
View Code

效果图:

 

再让我们看看“高能”的用法:

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4     <meta charset="utf-8" />
 5     <title></title>
 6     <style>
 7         body{ background: linear-gradient(63deg, #999 23%, transparent 23%) 7px 0, linear-gradient(63deg, transparent 74%, #999 78%), linear-gradient(63deg, transparent 34%, #999 38%, #99958%, transparent 62%), #444; background-size: 16px 48px;}
 8     </style>
 9 </head>
10 <body>
11 </body>
12 </html>
View Code

效果图:

 

怎么样,效果是不是很酷炫?再瞧瞧其他的:

还有更多好看的就不展示了,源自国外大牛:http://lea.verou.me/css3patterns/#chocolate-weave

 

其中的几个重要知识点总结:

■Ⅰ.“background”的绘制顺序是从后面的开始向前面的绘制的,百说不如一栗:

1 background: linear-gradient(45deg, #dca 12%, transparent 0, transparent 88%, #dca 0),linear-gradient(135deg, transparent 37%, #a85 0, #a85 63%, transparent 0),linear-gradient(45deg, transparent 37%, #dca 0, #dca 63%, transparent 0) #753;background-size: 25px 25px;

background绘制时是从linear-gradient(45deg, transparent 37%, #dca 0, #dca 63%, transparent 0) #753绘制到...头部的linear-gradient(45deg, #dca 12%, transparent 0, transparent 88%, #dca 0)渐变样式。所以这要注意了。

■Ⅱ.每一个使用“linear-gradient”绘制出来的渐变效果,都可以看作是一张背景图。因为,这个可以在“background-size”里设置(每个背景图的大小用逗号“,”区分)。

■Ⅲ.【非常重要,制作复杂的背景图并不难,但是你得知道“background-repeat”的原理就是每一张背景图都按照你设定的“属性”去绘制。如果你不知道这个原理,甚至没注意到。那么当你第一次看到这么漂亮的背景效果,想自己动手丰衣足食的时候却发现,“What is this”,看看我第一次写的背景效果。

 

第一次写的:

理想样子:

 

实际样式:

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta charset="utf-8" />
 5 <title></title>
 6 <style>
 7 body{
 8     background:linear-gradient(to right, transparent 0%, #F00 0%, #F00 100%, transparent 100%) 25px 25px,
 9     linear-gradient(to top,transparent 0%, #0F0 0%, #0F0 50%, transparent 50%),
10     linear-gradient(to right, transparent 0%, #F00 0%, #F00 50%, transparent 50%),
11     linear-gradient(to right, transparent 50%, #0F0 50%, #0F0 100%, transparent 100%);
12     
13     background-color:#FFF;
14     background-size:25px 25px, 50px 50px, 50px 50px, 50px 50px;
15     background-repeat:repeat;
16 }
17 </style>
18 </head>
19 <body>
20 </body>
21 </html>
View Code
效果图:

 

 ⊙︿⊙ 好桑心,怎么整个网页红色的?

 

其实这其中就是background-repeat”的原理问题:每个图片都是x、y复制绘制的“background-repeat:repeat”,所以当“background-size”不是一致的时候,复制绘制的位置也是不一样的。

知道是这个原因了,改动一下。

正确的样式:

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta charset="utf-8" />
 5 <title></title>
 6 <style>
 7 body{
 8     background:linear-gradient(135deg, transparent 0%, #F00 0%, #F00 25%, transparent 25%) 25px 25px,
 9     linear-gradient(315deg, transparent 0%, #F00 0%, #F00 25%, transparent 25%),
10     linear-gradient(to top,transparent 0%, #0F0 0%, #0F0 50%, transparent 50%),
11     linear-gradient(to right, transparent 0%, #F00 0%, #F00 50%, transparent 50%),
12     linear-gradient(to right, transparent 50%, #0F0 50%, #0F0 100%, transparent 100%);
13     
14     background-color:#FFF;
15     background-size:50px 50px;
16     background-repeat:repeat;
17 }
18 </style>
19 </head>
20 <body>
21 </body>
22 </html>
View Code

效果图:

 

知道原理才是硬道理 ╰( ̄▽ ̄)╮

关于爱程序网 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助