博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[15]CSS3 渐变效果
阅读量:6515 次
发布时间:2019-06-24

本文共 3187 字,大约阅读时间需要 10 分钟。

一.线性渐变

HTML5 中 CSS3 背景渐变功能,主要有两种渐变方式:线性渐变和径向(放射性)渐变。

CSS3 提供了 linear-gradient 属性实现背景颜色的渐变功能。在以前,这种效果必须采用图片才能实现的。首先,我们先看一下它的样式表,如下:

属性值 linear-gradient(方位, 起始色, 末尾色)
方位 可选参数,渐变的方位。可以使用的值有:to top、to top right、to right、to bottom、to bottom left、to left、to top left。
起始色 必选参数,颜色值
末尾色 必选参数,颜色值
//两个必须参数background-image: linear-gradient(orange,green);//增加一个方位background-image: linear-gradient(to top,orange,green);

通过 top、left、right、bottom 这四组实现的渐变方向有时比较单一,我们可以使用以角度单位的数值来设置方位。比如 0 度(0deg)相当于 to top;角度会沿逆时针方向随着你的角度的增加而增加。

//通过角度设置方位,0 ~ 360 度之间,可以是负值background-image: linear-gradient(45deg,orange,green);//多色线性渐变background-image: linear-gradient(-45deg,orange,green,blue,red);//通过百分比设置多色线性位置background-image: linear-gradient(-45deg, orange 0%, green 20%, blue 40%,red 100%);

默认情况下:起始颜色的百分比位置是 0%,末尾颜色的百分比位置是 100%,其他位置按照平均值分配。也可以使用 px 像素来设定,但计算麻烦点。

//结合背景,并使用透明渐变实现强大层次感background-color: red;background-image: linear-gradient(to top right, rgba(0,0,0,0.6),rgba(0,0,0,0));//重复渐变属性值background-image: repeating-linear-gradient(to top, orange 10px, green 30px);

目前最新的主流浏览器都支持 CSS3 的渐变属性,那么对于之前的浏览器支持度如何呢?可以参考如下的表:

支持度 Opera Firefox Chrome Safari IE
部分支持需带前缀 11.5 4 ~ 9 4 ~ 5
支持需带前缀 3.6 ~ 15 10 ~ 25 5.1 ~ 6
支持不带前缀 12.1+ 16+ 26+ 6.1+ 10.0+

这里提到了部分支持,说明当时可能渐变还尚未完善,但可以通过添加前缀来使用它了。具体哪些没完善,已经无法考证了,版本太过久远。那么支持带前缀和不支持带前缀的完整格式如下:

//加上兼容前缀background-image: -webkit-linear-gradient(to top, orange, green);background-image: -moz-linear-gradient(to top, orange, green);background-image: -o-linear-gradient(to top, orange,green);background-image: linear-gradient(to top, orange, green);

repeating-linear-gradient 属性值和 linear-gradient 基本相同,不在赘述。

二.径向渐变

CSS3 提供了径向渐变,也叫做放射性渐变:radial-gradient 属性值。它是从一个点向四周发散的方式扩展。属性值样式表如下:

属性 radial-gradient(方位, 起始色, 末尾色)
方位 可选参数,径向的方位。可以使用的值有:像素、百分比、固定值,或复合搭配使用
起始色 必选参数,颜色值
末尾色 必选参数,颜色值
//两个必选参数background-image: radial-gradient(orange, green);//如果想设置第一个可选参数,有一种做法是设置为:cirlce(圆形)或 ellipse(椭圆形)。默认是椭圆形。background-image: radial-gradient(circle, orange, green);
形状 说明
circle 圆形
ellipse 椭圆形,默认值
//不单单可以设置形状,还可以设置形状的发散方向background-image: radial-gradient(circle at top, orange, green);
方向 说明
top 从顶部发散
left 从左侧发散
right 从右侧发散
bottom 从底部发散
center 从中间发散
//也可以复合方向,比如右下方background-image: radial-gradient(circle at right bottom, orange,green);//可以设置发散的距离,即圆的半径长度background-image: radial-gradient(circle closest-side, orange, green);
半径关键字 说明
closest-side 指定径向渐变的半径长度为从圆心到离圆心最近的边
closest-corner 指定径向渐变的半径长度为从圆心到离圆心最近的角
farthest-side 指定径向渐变的半径长度为从圆心到离圆心最远的边
farthest-corner 指定径向渐变的半径长度为从圆心到离圆心最远的角
//关键字有点拗口,可以用像素表示半径,但不接受百分比background-image: radial-gradient(circle 50px, orange, green);//同样,也有重复背景方式background-image: repeating-radial-gradient(circle 50px, orange,green);//兼容模式background-image: -webkit-radial-gradient(circle, orange, green);background-image: -moz-radial-gradient(circle, orange, green);background-image: -o-radial-gradient(circle, orange,green);background-image: radial-gradient(circle, orange, green);//两个重复背景只要加上前缀就是兼容模式了background-image: -webkit-repeating-radial-gradientbackground-image: -moz-repeating-radial-gradientbackground-image: -o-repeating-radial-gradientbackground-image: repeating-radial-gradient

转载于:https://www.cnblogs.com/pengtdy/p/8306291.html

你可能感兴趣的文章
2017数据库大趋势 PostgreSQL最受关注
查看>>
企业如何进行ERP项目的招标?
查看>>
孙正义2017最新演讲:信息革命的新世界正在到来,连睡觉都觉得浪费
查看>>
《机器人自动化:建模、仿真与控制》一一2.4习题
查看>>
C++17功能列表现在完成,进入复查阶段
查看>>
新手教程:您必须了解的15套JavaScript框架与库
查看>>
研究显示:广告拦截应用正在破坏互联网
查看>>
优云·小课堂 第八期:运维自动化的魅力
查看>>
稳定+性能+价格,阿里云发力ECS企业级产品
查看>>
Skype for Linux Alpha 1.13发布:支持发送短信
查看>>
新浪微博迷失“微”属性
查看>>
国外黑客成功在iPhone7上越狱iOS10
查看>>
写个软件来防止服务器网站CPU百分百
查看>>
工业物联网底层数据平台 Tulip 获1300万美元A轮融资
查看>>
2017年中国智慧城市PPP模式发展情况分析
查看>>
治理校园网络安全离不开威胁情报大数据
查看>>
和联想玩耍的超融合厂商不只一两家
查看>>
网络安全保卫战不容有失
查看>>
看透CRM五大理念,用好经营利器
查看>>
Facebook将指导计算机学习用户发表的任何内容
查看>>