面试题之 CSS 渐变用法介绍
CSS3 定义了两种渐变:线性渐变(Linear Gradients)和 径向渐变(Radial Gradients),而这个属性只有 IE10 以上才兼容,完了我们讨论一下渐变的兼容问题。渐变属于背景图片中的一种,所以在 CSS 属性中,写 background 可以写 background-image 也可以,下面都是用 background 来写。
线性渐变(linear-gradient)
特点 :就是向一个方向进行颜色渐变,上/下/左/右/对角线
要素 :方向,颜色(起始,终止,中间色)
语法 :background: linear-gradient(to direction, color-start, color-stop1, ... , color-end);
使用 :
第一个参数(方向,可忽略)
1. 默认第一个参数如果不写就是从上到下的
background: linear-gradient(hotpink, darkblue);
2. 如果有第一个参数(top/left/bottom/right)
如果是原生写法记得要加 to,所以后面的方向正好相反,而且对角线的时候上下和左右可以互换位置
- 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);
3. 使用角度也可以angle(弧度值)进行控制
所有的颜色都是从中心出发,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);
第二个参数(颜色)
1. 可以使用英文字母进行颜色控制
background: linear-gradient(slateblue, cornflowerblue);
当然如果使用transparent可以看到全透明的效果渐变
background: linear-gradient(transparent, cornflowerblue);
2. 可以使用16进制#RRGGBB进行颜色控制
background: linear-gradient(#fc466b, #3f5efb);
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和火狐浏览器的效果图:
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*/
5. 使用多个颜色控制
只需要在后面加值就好了
background: linear-gradient(#3a1c71, #d76d77,#ffaf7b);
6. 使用多个有指定范围的颜色控制
在颜色后面加百分比,就可以控制在整个宽度的百分之多少的时候到达某一个颜色值
background: linear-gradient(#3a1c71, #d76d77,#ffaf7b);
background: linear-gradient(#3a1c71, #d76d77 20% ,#ffaf7b 70%);
background: linear-gradient(#3a1c71, #d76d77 80% ,#ffaf7b 90%);
线性渐变总写法
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);
2. 如果传一个值半径
background: radial-gradient(300px,hotpink, darkblue);
background: radial-gradient(200px,hotpink, darkblue);
3 .如果传两个半径值
传两个值默认为椭圆,一个是横向的长度,一个是纵向的长度
background: radial-gradient(200px 50px,hotpink, darkblue);
background: radial-gradient(50px 100px,hotpink, darkblue);
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);
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);
第一个参数中的二个参数(形状,可忽略)
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)
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);
第一个参数中的第三个参数(方向,可忽略)
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);
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);
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);
第二个参数(颜色)
颜色在线性渐变中已经讨论过,径向渐变与线性渐变等同。这里只阐述不同的部分:
只是径向渐变再算百分比的时候,颜色过渡是从内而外进行的
background: radial-gradient(#ffaf7b, #d76d77,#3a1c71);
background: radial-gradient(#ffaf7b, #d76d77 20% ,#3a1c71 70%);
background: radial-gradient(#ffaf7b, #d76d77 80% ,#3a1c71 90%);
径向渐变总写法
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%);
兼容问题
所说的兼容问题,就是各个浏览器的兼容性问题。
第一步只需要添加私有前缀就可以解决。
注意标准语法要写在最下面,带有私有前缀的就不加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); /* 标准的语法 */
第二步主要针对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)); /* 标准的语法 */
特殊效果
进度条动画
效果是什么样的?分析设置颜色渐变的角度、颜色和范围。然后设置从左到右的动画,实现:
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>
立体小球
分析:背景色设置一个,渐变是黑色的透明到不透明的渐变,外面的轮廓是圆。
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>
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

上一篇: JavaScript 中没有重载
下一篇: 面试中一些回答不够好的题(Vue 居多)
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
{{ commentTitle }}