CSS技巧(1)· CSS渐变 linear-gradient

前言:

  不论在网页设计中,还是传统的媒介中,各种尺寸,颜色,角度的图案在视觉中无处不在,要想在网页中实现复杂的图案,其过程往往不够理想,过去,我们可以创建一个单独的位图文件,然后每次需要做调整的时候,都要用图片编辑器处理它,我们也可以使用SVG代替位图,但是这样子还是存在一个独立的文件,会影响网页加载速度。如果可以在CSS中创建复杂的图案,该有多好,于是,接下来我整理了一些CSS渐变实现复杂图案的例子,便于以后直接使用

   

语法:

<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> ]?

例子:

 垂直条纹

background:linear-gradient(to right,#79b 15px,#58a 0);
background-size:30px 30px;

斜向条纹

 background:repeating-linear-gradient(45deg,
             #79b,#79b 10px,#58a 0,#58a 20px);    

注:如果把第二个色标的位置值设为0,意味着他的位置值就会被浏览器调整为前一个色标的位置值。

切角效果的按钮

.btn{
  width: 58px;
  height: 24px; 
  font-size:14px;
  line-height:24px;
  color:#fff;
  text-align:center;
  padding-right:8.4px;
  border-radius:3px;
  background: red;
  background:
    linear-gradient(-135deg, transparent 8.4px, red 0) top, linear-gradient(-45deg, transparent 8.4px,red 0) bottom;
  background-size:100% 50%;
  background-repeat:no-repeat;
}

  注:① 在这里我们使用了两层渐变,默认情况下,他们都会填满整个元素,因此会相互覆盖,于是使用了 background-size 让每层渐变只占据整个元素的一半面积,但是两层渐变还是相互覆盖的,因为我们还需要关闭 background-repeat;关于 第一个可选参数 angle 角度的问题,其实是这样的,角度按照 顺时针方向,y轴对称 ,如下图:

 

弧形切角(使用径向渐变)

  background:
    radial-gradient(circle at top left,transparent 10px,#58a 0)top left,
  radial-gradient(circle at top right,transparent 10px,#58a 0) top right,
  radial-gradient(circle at bottom left,transparent 10px,#58a 0) bottom left,
  radial-gradient(circle at bottom right,transparent 10px,#58a 0)bottom right; background-size:50% 50%; background-repeat:no-repeat;

语法:

radial-gradient( [ circle || <length> ] [ at <position> ]? ,
| [ ellipse || [<length> | <percentage> ]{2}] [ at <position> ]? ,
| [ [ circle | ellipse ] || <extent-keyword> ] [ at <position> ]? ,
| at <position> ,
<color-stop> [ , <color-stop> ]+ )

注:参数1 的position可省,默认中心

 棋盘

#demo {
  width:100px;
  height:100px;
  background:#eee;
  background:linear-gradient(45deg,#bbb 25%,transparent 0),
   linear-gradient(45deg,transparent 75%,#bbb 0),
    linear-gradient(45deg,#bbb 25%,transparent 0),
   linear-gradient(45deg,transparent 75%,#bbb 0); 
  background-position:0 0,10px 10px,10px 10px;
  background-size:20px 20px;
}
//简写
#demo {
  width:100px;
  height:100px;
  background:#eee;
  background:linear-gradient(45deg,#bbb 25%,transparent 0),
   linear-gradient(45deg,transparent 75%,#bbb 0)10px 10px,
    linear-gradient(45deg,#bbb 25%,transparent 0)10px 10px,
   linear-gradient(45deg,transparent 75%,#bbb 0); 
  background-size:20px 20px;
}

 

结束语

     使用CSS渐变可以灵活的实现各种复杂的图案,更多实例可以参看 http://lea.verou.me/css3patterns/

 

posted @ 2017-02-18 00:20  Kasmine  阅读(730)  评论(0编辑  收藏  举报