Css渐变gradient专题

css渐变(专题)

【目录】css

  • css渐变(专题)
    • 线性渐变(linear-gradient)
      • 第一个参数(方向,可忽略)
        • 1. 默认第一个参数若是不写就是从上到下的
        • 2. 若是有第一个参数(top/left/bottom/right)
        • 3. 使用角度也能够angle(角度值deg)进行控制
      • 第二个参数(颜色)
        • 1. 能够使用英文字母进行颜色控制
        • 2. 能够使用16进制#RRGGBB进行颜色控制
        • 3. 能够使用16进制加透明度#RRGGBBAA进行颜色控制
        • 4. 使用rgb/rgba进行颜色控制
        • 5. 使用多个颜色控制
        • 6. 使用多个有指定范围的颜色控制
      • 线性渐变总写法
    • 径向渐变(radial-gradient)
      • 第一个参数中的第一个参数(半径,可忽略)
        • 1. 第一个参数不写就默认从中间开始,样式为圆形
        • 2. 若是传一个值半径
        • 3 .若是传两个半径值
        • 4. 若是传关键字(closest-side/closest-corner/farthest-side/farthest-corner)
          • 4.1 若是是圆形
          • 4.2 若是是椭圆
      • 第一个参数中的二个参数(形状,可忽略)
        • 1. 若是只参数shape(circle,ellipse)
        • 2. 若是是加上长度范围和形状
      • 第一个参数中的第三个参数(方向,可忽略)
        • 1. 若是第一个有参数(center/top/bottom/left/right)
        • 2. 若是方向为具体数值肯定圆心
        • 3. 若是方向为百分比肯定圆心
      • 第二个参数(颜色)
      • 径向渐变总写法
    • 兼容问题
    • 特殊效果
      • 进度条
      • 动画立体小球
    • 参考

css3定义了两种渐变:**线性渐变(Linear Gradients)**or 径向渐变(Radial Gradients)html

而这个属性只有IE10以上才兼容,完了咱们讨论一下渐变的兼容问题。css3

渐变属于背景图片中的一种,因此在css属性中,写==background== 能够写==background-image== 也能够,下面都是用background来写。web

线性渐变(linear-gradient)

==特色== :就是向一个方向进行颜色渐变,上/下/左/右/对角线浏览器

==要素== :方向,颜色(起始,终止,中间色)ide

==语法== :background: linear-gradient(to direction, color-start, color-stop1, ... , color-end);动画

==使用== :spa

第一个参数(方向,可忽略)

1. 默认第一个参数若是不写就是从上到下的

background: linear-gradient(hotpink, darkblue);
复制代码

效果图: 3d

derection1.png

2. 若是有第一个参数(top/left/bottom/right)

==若是是原生写法记得要加to,因此后面的方向正好相反,并且对角线的时候上下和左右能够互换位置==code

to bottom(从上边开始)

to right(从左边开始)

to left(从右边开始)

to top(从下边开始)

to top left(从右下角开始)

to top right(从左下角开始)

to bottom left(从右上角开始)

to bottom right(从右下角开始)

background: linear-gradient(to bottom,hotpink, darkblue);
background: linear-gradient(to right,hotpink, darkblue);
background: linear-gradient(to left,hotpink, darkblue);
background: linear-gradient(to top,hotpink, darkblue); 
background: linear-gradient(to right bottom,hotpink, darkblue); 
background: linear-gradient(to top right,hotpink, darkblue);
background: linear-gradient(to left bottom,hotpink, darkblue);
background: linear-gradient(to top left,hotpink, darkblue);
复制代码

derection2.png

3. 使用角度也能够angle(角度值deg)进行控制

全部的颜色都是从中心出发,0deg是to top的方向,顺时针是正,逆时针是负

0deg / 360deg (从下到上)

90deg (从左到右)

180deg (从上到下)

270deg / -90deg (从右到左)

45deg (对角线左下到右上)

background: linear-gradient(0deg,#fc466b, #3f5efb);
background: linear-gradient(90deg,#fc466b, #3f5efb);
background: linear-gradient(180deg,#fc466b, #3f5efb);
background: linear-gradient(270deg,#fc466b, #3f5efb);
background: linear-gradient(360deg,#fc466b, #3f5efb);
background: linear-gradient(-90deg,#fc466b, #3f5efb);
background: linear-gradient(-180deg,#fc466b, #3f5efb);
background: linear-gradient(45deg,#fc466b, #3f5efb);
复制代码

效果图:

derection3.png

第二个参数(颜色)

1. 能够使用英文字母进行颜色控制

background: linear-gradient(slateblue, cornflowerblue);
复制代码

效果图:

color1.png

固然若是使用transparent能够看到全透明的效果渐变

background: linear-gradient(transparent, cornflowerblue);
复制代码

效果图:

color7.png

2. 能够使用16进制#RRGGBB进行颜色控制

background: linear-gradient(#fc466b, #3f5efb);
复制代码

效果图:

color2.png

3. 能够使用16进制加透明度#RRGGBBAA进行颜色控制

​ 所谓16进制加透明度通常不怎么使用也不推荐使用,为何不推荐使用呢?那就是==会带来比较大的兼容问题== ,可是有时候不得不用,由于要处理透明度的兼容问题。

​ 问题在哪里?

Chrome和火狐浏览器是支持的,形式是==#rrggbbaa== 可是这种形式在IE中就是不支持的。

IE浏览器是什么状况呢?IE9如下若是加透明度是按照==#aarrggbb== 的形式来的,可是这种形式IE10和IE11都是不支持的,因此用这个办法,IE10和IE11都出不来。因此==不推荐使用== 。

AA指透明度:00表示全透明,FF表示彻底不透明。

RR指红色值

GG指绿色值

BB指蓝色值

​ ==0~1的透明度如何转化为00-FF的十六进制的透明度呢?==

Math.round(256 * opacity).toString(16)

下面把2中的代码进行50%的透明度试试:

background: linear-gradient(#7ffc466b, #7f3f5efb);
复制代码

下面是Chrome和火狐浏览器的效果图:

color6.png

4. 使用rgb/rgba进行颜色控制

background: linear-gradient(rgb(255,237,188), rgb(237,66,100));   /*rbg*/
background: linear-gradient(rgb(255,237,188,.5), rgb(237,66,100,.5));  /*rgba*/
复制代码

效果图:

color3.png

5. 使用多个颜色控制

只须要在后面加值就行了

background: linear-gradient(#3a1c71, #d76d77,#ffaf7b);
复制代码

效果图:

color4.png

6. 使用多个有指定范围的颜色控制

在颜色后面加百分比,就能够控制在整个宽度的百分之多少的时候到达某一个颜色值

background: linear-gradient(#3a1c71, #d76d77,#ffaf7b); 
background: linear-gradient(#3a1c71, #d76d77 20% ,#ffaf7b 70%); 
background: linear-gradient(#3a1c71, #d76d77 80% ,#ffaf7b 90%); 
复制代码

效果图:

color5.png

线性渐变总写法

background: linear-gradient(to bottom,#3a1c71, #d76d77 80% ,#ffaf7b 90%); 
复制代码

径向渐变(radial-gradient)

==特色== :就是一个中心点向外围进行颜色渐变

==要素== :方向,形状,大小,颜色(起始,终止,中间色)

==语法== :background: radial-gradient(size shape at position,start-color, ..., last-color);

==使用== : ==都是使用200px * 200px的div==

第一个参数中的第一个参数(半径,可忽略)

1. 第一个参数不写就默认从中间开始,样式为圆形

background: radial-gradient(hotpink, darkblue);
复制代码

效果图:

dc1.png

2. 若是传一个值半径

background: radial-gradient(300px,hotpink, darkblue);
background: radial-gradient(200px,hotpink, darkblue);
复制代码

====

效果图:

size2.png

3 .若是传两个半径值

==传两个值默认为椭圆,一个是横向的长度,一个是纵向的长度==

background: radial-gradient(200px 50px,hotpink, darkblue);
background: radial-gradient(50px 100px,hotpink, darkblue);
复制代码

效果图:

size3.png

4. 若是传关键字(closest-side/closest-corner/farthest-side/farthest-corner)

==这个大小是由位置决定的==

4.1 若是是圆形
/*closest-side*/
background: radial-gradient(closest-side,#ffaf7b, #d76d77 ,#3a1c71);
/*40%只写一个表示40% 50%*/
background: radial-gradient(closest-side circle at 40%,#ffaf7b, #d76d77 ,#3a1c71);  
background: radial-gradient(closest-side circle at 20% 30%,#ffaf7b, #d76d77 ,#3a1c71);
/*closest-corner*/
background: radial-gradient(closest-corner,#ffaf7b, #d76d77 ,#3a1c71);
background: radial-gradient(closest-corner circle at 40%,#ffaf7b, #d76d77 ,#3a1c71);
background: radial-gradient(closest-corner circle at 20% 30%,#ffaf7b, #d76d77 ,#3a1c71);
/*farthest-side*/
background: radial-gradient(farthest-side,#ffaf7b, #d76d77 ,#3a1c71);
background: radial-gradient(farthest-side circle at 40%,#ffaf7b, #d76d77 ,#3a1c71);
background: radial-gradient(farthest-side circle at 20% 30%,#ffaf7b, #d76d77 ,#3a1c71);
/*farthest-corner*/
background: radial-gradient(farthest-corner,#ffaf7b, #d76d77 ,#3a1c71);
background: radial-gradient(farthest-corner circle at 40%,#ffaf7b, #d76d77 ,#3a1c71);
background: radial-gradient(farthest-corner circle at 20% 30%,#ffaf7b, #d76d77 ,#3a1c71);
复制代码

效果图:

sizec2.png

4. 2 若是是椭圆
/*closest-side*/
background: radial-gradient(closest-side ellipse,#ffaf7b, #d76d77 ,#3a1c71);
/*40%只写一个表示40% 50%*/
background: radial-gradient(closest-side ellipse at 40%,#ffaf7b, #d76d77 ,#3a1c71);  
background: radial-gradient(closest-side ellipse at 20% 30%,#ffaf7b, #d76d77 ,#3a1c71);
/*closest-corner*/
background: radial-gradient(closest-corner ellipse,#ffaf7b, #d76d77 ,#3a1c71);
background: radial-gradient(closest-corner ellipse at 40%,#ffaf7b, #d76d77 ,#3a1c71);
background: radial-gradient(closest-corner ellipse at 20% 30%,#ffaf7b, #d76d77 ,#3a1c71);
/*farthest-side*/
background: radial-gradient(farthest-side ellipse,#ffaf7b, #d76d77 ,#3a1c71);
background: radial-gradient(farthest-side ellipse at 40%,#ffaf7b, #d76d77 ,#3a1c71);
background: radial-gradient(farthest-side ellipse at 20% 30%,#ffaf7b, #d76d77 ,#3a1c71);
/*farthest-corner*/
background: radial-gradient(farthest-corner ellipse,#ffaf7b, #d76d77 ,#3a1c71);
background: radial-gradient(farthest-corner ellipse at 40%,#ffaf7b, #d76d77 ,#3a1c71);
background: radial-gradient(farthest-corner ellipse at 20% 30%,#ffaf7b, #d76d77 ,#3a1c71);
复制代码

效果图:

sizec3.png

第一个参数中的二个参数(形状,可忽略)

1. 若是只参数shape(circle,ellipse)

==若是div是正方形那么circle和ellipse并无什么区别,可是若是是长方形,那么ellipse就会根据长度进行压缩==

background: radial-gradient(circle,hotpink, darkblue); /*下图1和3*/
background: radial-gradient(ellipse,hotpink, darkblue); /*下图2和4*/
复制代码

效果图(左边两个是200px * 200px ,右边两个是200px *100px)

circle1.png

2. 若是是加上长度范围和形状

==该范例要说明半径要写到形状前面,且半径做用大于形状==

background: radial-gradient(300px circle,hotpink, darkblue);
background: radial-gradient(200px circle,hotpink, darkblue);
background: radial-gradient(100px circle,hotpink, darkblue);
background: radial-gradient(50px circle,hotpink, darkblue);
background: radial-gradient(0px circle,hotpink, darkblue);

/*若是这里加了长短轴的尺寸后面又写了circle,那么circle是不起做用的,出来仍是一个椭圆*/
background: radial-gradient(200px 50px ellipse,hotpink, darkblue);
复制代码

效果图:

size1.png

第一个参数中的第三个参数(方向,可忽略)

1. 若是第一个有参数(center/top/bottom/left/right)

==若是是原生写法记得要加at,并且对角线的时候上下和左右能够互换位置==

background: radial-gradient(at center,hotpink, darkblue);
background: radial-gradient(at top,hotpink, darkblue);
background: radial-gradient(at bottom,hotpink, darkblue);
background: radial-gradient(at left,hotpink, darkblue);
background: radial-gradient(at right,hotpink, darkblue);
background: radial-gradient(at center center,hotpink, darkblue);
background: radial-gradient(at top left,hotpink, darkblue);
background: radial-gradient(at top right,hotpink, darkblue);
background: radial-gradient(at bottom right,hotpink, darkblue);
background: radial-gradient(at bottom left,hotpink, darkblue);
复制代码

效果图:

dc2.png

2. 若是方向为具体数值肯定圆心

==能够是正数也能够是负数,能够超出范围==

background: radial-gradient(circle at 0 0,hotpink, darkblue);
background: radial-gradient(circle at 50px 50px,hotpink, darkblue);
background: radial-gradient(circle at 100px 50px,hotpink, darkblue);
background: radial-gradient(circle at 50px 100px,hotpink, darkblue);
background: radial-gradient(circle at 100px 100px,hotpink, darkblue);
复制代码

效果图:

dc3.png

3. 若是方向为百分比肯定圆心

==能够是整数也能够是负数,能够超出范围,方向和上面的同样==

background: radial-gradient(circle at 0 0,hotpink, darkblue);
background: radial-gradient(circle at 25% 25%,hotpink, darkblue);
background: radial-gradient(circle at -25% 50%,hotpink, darkblue);
background: radial-gradient(circle at 50% 150%,hotpink, darkblue);
background: radial-gradient(circle at 50% 50%,hotpink, darkblue);
复制代码

效果图:

dc4.png

第二个参数(颜色)

颜色在线性渐变中已经讨论过,径向渐变与线性渐变等同。这里只阐述不一样的部分:

只是径向渐变再算百分比的时候,颜色过渡是从内而外进行的

background: radial-gradient(#ffaf7b, #d76d77,#3a1c71); 
background: radial-gradient(#ffaf7b, #d76d77 20% ,#3a1c71 70%); 
background: radial-gradient(#ffaf7b, #d76d77 80% ,#3a1c71 90%); 
复制代码

效果图:

color8.png

径向渐变总写法

background: radial-gradient(100px circle at 75% 75%,#ffaf7b, #d76d77 20% ,#3a1c71 60%); 
background: radial-gradient(200px 100px ellipse at 25% 25%,#ffaf7b, #d76d77 60% ,#3a1c71 90%); 
复制代码

效果图:

all.png

兼容问题

所说的兼容问题,就是各个浏览器的兼容性问题。

  1. 第一步只须要添加私有前缀就能够解决。

    ==注意标准语法要写在最下面,带有私有前缀的就不加to了,方向就是起始点==

    /*线性渐变*/
    background: -webkit-linear-gradient(left, hotpink , darkblue); /* Safari 5.1 - 6.0 */
    background: -o-linear-gradient(left, hotpink, darkblue); /* Opera 11.1 - 12.0 */
    background: -moz-linear-gradient(left, hotpink, darkblue); /* Firefox 3.6 - 15 */
    background: linear-gradient(to right, hotpink , darkblue); /* 标准的语法 */
    /*径向渐变*/
    background: -webkit-radial-gradient(center, hotpink , darkblue); /* Safari 5.1 - 6.0 */
    background: -o-radial-gradient(center, hotpink, darkblue); /* Opera 11.1 - 12.0 */
    background: -moz-radial-gradient(center, hotpink, darkblue); /* Firefox 3.6 - 15 */
    background: radial-gradient(at center, hotpink , darkblue); /* 标准的语法 */
    复制代码
  2. 第二步主要针对IE9如下的浏览器,是不支持渐变效果的。

    ==解决办法就是使用IE私有的渐变滤镜==

    filter:progid:DXImageTransform.Microsoft.gradient(startcolorstr=hotpink,endcolorstr=darkblue,gradientType=1);
    /**
    @ 第一个参数:startcolorstr 表示起始颜色(英文字母 or 十六进制)
    @ 第二个参数:endcolorstr 表示终止颜色(英文字母 or 十六进制)
    @ 第三个参数:gradientType 表示方向(1为横向渐变,0为纵向渐变)
    */
    复制代码

    若是想有白透明的效果,就使用8字符的十六进制表示法,在上面也提到了,规则是==#AARRBBGG==

    因此若是还想要兼容IE9如下的浏览器就写成:

    /*50%透明度的#fc466b和50%透明度的#3f5efb*/
    filter:progid:DXImageTransform.Microsoft.gradient(startcolorstr=#7ffc466b,endcolorstr=#7f3f5efb,gradientType=1);/*兼容IE9如下*/
    background: -webkit-linear-gradient(left, rgba(252,70,107,.5) , rgba(63,94,251,.5)); /* 标准的语法 */
    background: -o-linear-gradient(left, rgba(252,70,107,.5) , rgba(63,94,251,.5)); /* 标准的语法 */
    background: -moz-linear-gradient(left, rgba(252,70,107,.5) , rgba(63,94,251,.5)); /* 标准的语法 */
    background: linear-gradient(to right, rgba(252,70,107,.5) , rgba(63,94,251,.5)); /* 标准的语法 */
    复制代码

    效果图:

    jianrong1.jpg

特殊效果

进度条动画

效果是什么样的?截图:

jindutiao.png

分析:设置颜色渐变的角度、颜色和范围。而后设置从左到右的动画。

实现:

body{
  margin:0;
  padding:0;
  /*为了展现方便就用灰色的背景*/
  background-color:#ccc;  
}

.load{
  width:500px;
  height:100px;
  /*若是渐变出不来,有一个背景颜色*/
  background:#fff;  
  margin:100px auto;
  /*间隔色的关键代码*/
  background-image:linear-gradient(
  	45deg,
    #fff 0%,
    #fff 25%,
    #000 25%,
    #000 50%,
    #fff 50%,
    #fff 75%,
    #000 75%,
    #000 100%
  );
  /*把刚才的背景压缩到100px * 100px之内的,没有设定不重复因此是重复的*/
  background-size: 100px 100px; 
  /*一秒播一次的永动动画*/
  animation: move 1s linear infinite; 
}

@keyframes move{
  0%{
    
  }
  100%{
    background-position:100px;  /*终止状态是移动到100px像素的位置,而后下一秒又开始从0px开始运动*/
  }
}


<div class="load"></div>
复制代码

立体小球

效果图:

ball.png

分析:背景色设置一个,渐变是黑色的透明到不透明的渐变,外面的轮廓是圆。

body {
  margin: 0;
  padding: 0;
  background-color: #F7F7F7;
}

.radial-gradient {
  width: 200px;
  height: 200px;
  margin: 40px auto;
  border-radius: 100px;
  background-color: hotpink; /*左边的没有背景色,右边的加了背景色*/
  background-image: radial-gradient(
    200px at 50px 60px,
    rgba(0, 0, 0, 0),
    rgba(0, 0, 0, 0.6)
  );
}

<div class="radial-gradient"></div>
复制代码

参考

再说线性渐变

再说径向渐变

相关文章
相关标签/搜索