页面中如果有两种或多种指定颜色之间的平滑过渡的渐变效果,会使得我们的视觉效果瞬间提升几个档次,在CSS3中有提供的多个渐变方式属性就能让我们轻松实现这样的渐变效果。
目前CSS渐变属性有六个,分别为:linear-gradient
(线性渐变),repeating-linear-gradient
(重复线性渐变),radial-gradient
(径向渐变),repeating-radial-gradient
(重复径向渐变),conic-gradient
(锥形渐变),repeating-conic-gradient
(重复锥形渐变); CSS渐变属性作用是从一种颜色平滑渐变到另一种颜色的图像,那么background-image
和border-image
属性都可以用渐变作为图片内容。 下面,我们就分别来看看这几个属性的效果
linear-gradient和repeating-linear-gradient
线性渐变
以直线的方式,可向左、向右、向上、向下、对角方向延伸,使用频率很高。要创建线性渐变
,需要指定两种及以上的颜值和方向,如果未指定方向,默认为上到下渐变。
使用语法:
1
| background-image: linear-gradient(direction, ColorStop1, ColorStop2, ...,ColorStopN);
|
- direction的取值有:
to right(向右)
、to bottom(向下)
、to bottom right
(向右下角)、180deg(向下)
- ColorStop为指定渐变颜色和渐变位置,颜色代码可以是十六进制颜色代码,RGB颜色代码。位置可以是百分比也可以是像素
1 2 3 4 5 6 7 8
| <div class="bg"> </div>
.bg{ width: 200px; height: 200px; background-image: linear-gradient( rgb(123, 255, 0),rgb(119, 0, 255)); }
|
data:image/s3,"s3://crabby-images/1eb8c/1eb8ce1cdb27a2ab9932e47371a7bc63097d8990" alt="默认从上到下"
1 2 3 4 5
| .bg{ width: 200px; height: 200px; background-image: linear-gradient(to bottom right, rgb(123, 255, 0),rgb(119, 0, 255)); }
|
data:image/s3,"s3://crabby-images/86f13/86f132977a58b936d926d6eb7e381ae8e135059e" alt="指定方向从左上角到右下角"
1 2 3 4 5
| .bg{ width: 200px; height: 200px; background-image: linear-gradient(to bottom right, rgb(123, 255, 0),rgb(119, 0, 255),rgb(255, 0, 43)); }
|
data:image/s3,"s3://crabby-images/dc989/dc98985abe542f3fb6ee685e06cad434c65789b4" alt="指定方向从左上角到右下角,设置多种渐变颜色"
1 2 3 4 5
| .bg{ width: 200px; height: 200px; background-image: linear-gradient(to bottom right, rgb(123, 255, 0) 0,rgb(251, 255, 0) 15%,rgb(119, 0, 255) 35% 80%,rgb(255, 0, 43)); }
|
data:image/s3,"s3://crabby-images/3dc5e/3dc5e19c9c9236e31930321444f18d32abc0d9b4" alt="指定方向从左上角到右下角,设置多种渐变颜色及颜色作用位置"
repeating-linear-gradient
用得可能比较少,它是基于linear-gradient
进行重复平铺操作
1 2 3 4 5
| .bg{ width: 200px; height: 200px; background-image: repeating-linear-gradient(to bottom, rgb(123, 255, 0) 0 ,rgb(251, 255, 0)10%,rgb(255, 0, 43)15%); }
|
data:image/s3,"s3://crabby-images/0b4e7/0b4e7cac35aa18a98d6bd3abe2eb8118502d2842" alt=""
前面都是渐变背景,我们再来看看渐变边框是什么效果
1 2 3 4 5 6 7
| .bg{ width: 200px; height: 200px; border-width:10px; border-style:solid; border-image:linear-gradient(to bottom right, rgb(123, 255, 0) 0,rgb(251, 255, 0) 15%,rgb(119, 0, 255) 35% 80%,rgb(255, 0, 43)) 1 10; }
|
data:image/s3,"s3://crabby-images/bf7d2/bf7d22eeaed4768103ee868c3a8fb04399acd91e" alt=""
radial-gradient
径向渐变
以由中心点由圆
或者椭圆
向外扩散,使用语法
1
| background-image: radial-gradient(shape size at position, ColorStop, ..., ColorStopN);
|
shape 圆类型,就两种:ellipse(椭圆)和circle (圆),默认ellipse
size 渐变大小,分别有farthest-corner(从圆心到圆最远的角为半径)
,farthest-side(从圆心到圆最远的边为半径)
,closest-corner(从圆心到圆最近的角为半径)
,closest-side(从圆心到圆最近的边为半径)
,Size
,默认是farthest-corner
,
position 位置:left
,right
,top
,bottom
,center
或者数值比分比,默认是center
ColorStop,渐变颜色和渐变位置
radial-gradient
的用法和linear-gradient
的用法相似
1 2 3 4 5
| .bg{ width: 200px; height: 200px; background-image: radial-gradient( rgb(123, 255, 0) 0,rgb(251, 255, 0) 15%,rgb(119, 0, 255) 35% 80%,rgb(255, 0, 43)); }
|
data:image/s3,"s3://crabby-images/728e9/728e9a67d1c2a951726734fe25aedf284cf69302" alt=""
1 2 3 4 5 6 7
| .bg{ width: 200px; height: 200px; border-width:10px; border-style:solid; border-image:radial-gradient(rgb(123, 255, 0) 0,rgb(251, 255, 0) 15%,rgb(119, 0, 255) 35% 80%,rgb(255, 0, 43)) 1 10; }
|
data:image/s3,"s3://crabby-images/3d64c/3d64cd3e193d06c5abd408a9ad53541c1a5f56e9" alt=""
conic-gradient
一般情况下,用conic-gradient
的场景比较少,但我们也可以基本了解一下。其基本语法:
1
| background-image: conic-gradient(from angle at position,ColorStop, ...,ColorStopN);
|
- from angle 起点角度,默认0deg
- position 位置:
left
,right
,top
,bottom
,center
或者数值比分比,默认是center
- ColorStop,渐变颜色和渐变位置
1 2 3 4 5
| .bg{ width: 200px; height: 200px; background-image: conic-gradient( rgb(123, 255, 0) 0,rgb(251, 255, 0) 15%,rgb(119, 0, 255) 35% 80%,rgb(255, 0, 43)); }
|
data:image/s3,"s3://crabby-images/87779/87779845592aab09269fecd3e1515820425c78bc" alt=""
1 2 3 4 5
| .bg{ width: 200px; height: 200px; background-image: conic-gradient(from 90deg at left, rgb(123, 255, 0) 0,rgb(251, 255, 0) 15%,rgb(119, 0, 255) 35% 80%,rgb(255, 0, 43)); }
|
data:image/s3,"s3://crabby-images/8f168/8f168230bcf955514c344c3800f0cc9a65aa15ee" alt=""
1 2 3 4 5 6 7
| .bg{ width: 200px; height: 200px; border-width:10px; border-style:solid; border-image:conic-gradient(from 90deg at left, rgb(123, 255, 0) 0,rgb(251, 255, 0) 15%,rgb(119, 0, 255) 35% 80%,rgb(255, 0, 43)) 1 10; }
|
data:image/s3,"s3://crabby-images/28315/2831526e5e0cd78a43d007c960b8e2826a54475a" alt=""