CSS函数(一)
大家都知道js函数,你们清楚css的函数么?
rgb()
对,没错,这就是一个典型的css函数。
那大家知道css有多少函数么,鄙人从w3cplus摘录了一些常用的css函数,w3cplus将其分为9大类,如下:
属性函数:attr()
颜色函数:rgb()、rgba()、hsl()、hsla()、hwb()、color-mod()
背景图片函数:linear-gradient()、radial-gradient()、conic-gradient()、repeating-linear-gradient()、repeating-radial-gradient()、repeating-conic-gradient()、image-set()、image()、url()、element()
数学函数:calc()、min()、max()、mixmax()、repeat()
转换函数:matrix()、matrix3d()、perspective()、rotate()、rotate3d()、rotateX()、rotateY()、rotateZ()、scale()、scale3d()、scaleX()、scaleY()、scaleZ()、skew()、skewX()、skewY()、translate()、translateX()、translateY()、translateZ()、translate3d()
图形函数:circle()、ellipse()、inset()、polygon()、path()
滤镜函数:blur()、brightness()、contrast()、drop-shadow()、grayscale()、hue-rotate()、invert()、opacity()、saturate()、sepia()
缓动函数:cubic-bezier()、steps()
其他函数:counter()、counters()、toggle()、var()、 symbols()
那我们就详细的介绍一下这9大类css函数吧,由于函数太多,将分为三部分并对其中常用及常见的函数进行讲述,并不会全部讲述。
一、属性函数
1.attr()
相信大家对attr()这个函数并不陌生,在jQuery中是不是使用过。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<input class="test-ipt" value="12" type="text">
</body>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/1.10.0/jquery.min.js"></script>
<script>
$('.test-ipt').attr('value') //拿到类名为test-ipt的input的值会为12
</script>
</html>
在jQuery中attr()函数是用来返回被选元素的属性值的,在css中也是用来返回被选元素的属性值的,用法肯定是完全不一样。
1.1用法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.test-a::after {
content: "-----使用attr()函数拿到a标签的href属性值为:"attr(href);
color: red;
text-decoration: inherit;
}
</style>
</head>
<body>
<a class="test-a" href="www.baidu.com">百度</a>
</body>
</html>
效果图
1.2浏览器支持
函数 | |||||
attr() | 2.0 | 3.0 | 1.0 | 3.0 | 9.0 |
二、颜色函数
1.rgb()
rgb()想必大家都不陌生吧,经常用吧,用来生成颜色的
R:红色,值为0 到 255 间的整数,也可以使用0%到100%
G:绿色,值为0 到 255 间的整数,也可以使用0%到100%
B:蓝色,值为0 到 255 间的整数,也可以使用0%到100%
1.1用法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.test-div {
width: 100px;
height: 100px;
background-color: rgb(68, 111, 222);
}
</style>
</head>
<body>
<div class="test-div"></div>
</body>
</html>
效果图
1.2浏览器支持
函数 | |||||
rgb() | 1.0 | 4.0 | 1.0 | 1.0 | 3.5 |
2.rgba()
rgba()与rgb()一样都是用来用来生成颜色的,但是rgba()可以修改颜色透明度
R:红色,值为0 到 255 间的整数,也可以使用0%到100%
G:绿色,值为0 到 255 间的整数,也可以使用0%到100%
B:蓝色,值为0 到 255 间的整数,也可以使用0%到100%
A:透明度,值为0到1之间的数值(0完全透明,1不透明)
1.1用法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.test-div {
width: 100px;
height: 100px;
background-color: rgba(68, 111, 222, 0.5); /* 透明度的0.5的0可以省略直接写成.5 */
}
</style>
</head>
<body>
<div class="test-div"></div>
</body>
</html>
效果图
1.2浏览器支持
函数 | |||||
rgba() | 1.0 | 4.0 | 1.0 | 1.0 | 3.5 |
3.hsl()
hsl()使用色相、饱和度、亮度来定义颜色,对于做设计的人来说这三个词并不陌生吧
H:色相,色彩的基本属性,如蓝色、黑色,取值范围0到360(0或360为红色,120为绿色,240为蓝色)
S:饱和度,色彩的纯度,值越高越纯,值越低越灰,取值范围0%到100%(0%为灰色,100%为全色)
L:亮度,值越高颜色向白色变化,值越低颜色向黑色变化,取值范围0%到100%(0%为黑色,50%为正常,100%为白色)
3.1使用
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.test-div {
padding-left: 10px;
width: 400px;
height: 40px;
line-height: 40px;
color: red;
}
.div1 {
background-color: hsl(240, 0%, 50%);
}
.div2 {
background-color: hsl(240, 100%, 50%);
}
.div3 {
background-color: hsl(240, 100%, 0%);
}
.div4 {
background-color: hsl(240, 100%, 100%);
}
.div5 {
background-color: hsl(120, 100%, 50%);
}
</style>
</head>
<body>
<div class="test-div div1">background-color: hsl(240, 0%, 50%);</div>
<div class="test-div div2">background-color: hsl(240, 100%, 50%);</div>
<div class="test-div div3">background-color: hsl(240, 100%, 0%);</div>
<div class="test-div div4">background-color: hsl(240, 100%, 100%);</div>
<div class="test-div div5">background-color: hsl(120, 100%, 50%);</div>
</body>
</html>
效果图
3.2浏览器支持
函数 | |||||
hsl() | 1.0 | 9.0 | 1.0 | 3.1 | 9.5 |
4.hsla()
hsla()与hsl()一样都是使用色相、饱和度、亮度来定义颜色,但是hsla()多了一个透明度
H:色相,色彩的基本属性,如蓝色、黑色,取值范围0到360(0或360为红色,120为绿色,240为蓝色)
S:饱和度,色彩的纯度,值越高越纯,值越低越灰,取值范围0%到100%(0%为灰色,100%为全色)
L:亮度,值越高颜色向白色变化,值越低颜色向黑色变化,取值范围0%到100%(0%为黑色,50%为正常,100%为白色)
A:透明度,值为0到1之间的数值(0完全透明,1不透明)
4.1使用
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.test-div {
padding-left: 10px;
width: 400px;
height: 40px;
line-height: 40px;
color: red;
}
.div1 {
background-color: hsla(240, 100%, 50%, 0);
}
.div2 {
background-color: hsla(240, 100%, 50%, .5);
}
.div3 {
background-color: hsla(240, 100%, 50%, 1);
}
</style>
</head>
<body>
<div class="test-div div1">background-color: hsla(240, 100%, 50%, 0);</div>
<div class="test-div div2">background-color: hsla(240, 100%, 50%, .5);</div>
<div class="test-div div3">background-color: hsla(240, 100%, 50%, 1);</div>
</body>
</html>
效果图
4.2浏览器支持
函数 | |||||
hsla() | 1.0 | 9.0 | 1.0 | 3.1 | 9.5 |
三、背景图片函数
1.url()
url()想必大家都不陌生,用于背景图资源,可以写入绝对url,相对url或数据格式的url,url()中的引号可加可不加
1.1用法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.test-div {
width: 360px;
height: 200px;
background-size: 100%;
}
.div1 {
/* 带引号的url地址 */
background-image: url('https://mmbiz.qpic.cn/mmbiz_jpg/D1DIysCG0CEUDia6vu4eA5R9p6lyhltxktAFo0dUichuNjpNsnnlibiadZ33TJGibLUxmicsesnYVjy7WKOOycDsLQ6Q/0?wx_fmt=jpeg')
}
.div2 {
/* 不带引号的url地址 */
background-image: url(https://mmbiz.qpic.cn/mmbiz_jpg/D1DIysCG0CEUDia6vu4eA5R9p6lyhltxktAFo0dUichuNjpNsnnlibiadZ33TJGibLUxmicsesnYVjy7WKOOycDsLQ6Q/0?wx_fmt=jpeg)
}
.div3 {
/* base64的图片地址 */
background-image: url('')
}
</style>
</head>
<body>
<div class="test-div div1"></div>
<div class="test-div div2"></div>
<div class="test-div div3"></div>
</body>
</html>
效果图
1.2浏览器支持
函数 | |||||
url() | 4.0 | 6.0 | 4.0 | 4.0 | 15.0 |
2.linear-gradient()
linear-gradient()创建一个表示两种或多种颜色线性渐变的图片
linear-gradient(direction,color1,color2,…)
参数1:渐变方向,也可以为角度值
后续参数:渐变的起止颜色
2.1用法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.test-div {
margin-bottom: 10px;
width: 500px;
height: 60px;
line-height: 60px;
color: #fff;
}
.div1 {
background-image: linear-gradient(to right, blue, red); /*参数1:渐变的方向,也可以为角度 后续参数:渐变的起止颜色*/
}
.div2 {
background-image: linear-gradient(to right, blue, red, yellow);
}
.div3 {
background-image: linear-gradient(to bottom, blue, red, yellow);
}
.div4 {
background-image: linear-gradient(45deg, blue, red, yellow);
}
</style>
</head>
<body>
<div class="test-div div1">background-image: linear-gradient(to right, blue, red);</div>
<div class="test-div div2">background-image: linear-gradient(to right, blue, red, yellow);</div>
<div class="test-div div3">background-image: linear-gradient(to bottom, blue, red, yellow);</div>
<div class="test-div div4">background-image: linear-gradient(45deg, blue, red, yellow);</div>
</body>
</html>
效果图
2.2浏览器支持
函数 | |||||
liner-gradient() | 26.0 | 10.0 | 16.0 | 6.1 | 12.1 |
3.radial-gradient()
radial-gradient()创建一个表示两种或多种颜色径向渐变的图片
radial-gradient(shape size position,color1,color2,…)
参数1:
圆的类型
ellipse:椭圆形的径向渐变(默认值)
circle:圆形的径向渐变
渐变的大小
farthest-corner:径向渐变的半径长度为从圆心到离圆心最远的角(默认值)
closest-side:径向渐变的半径长度为从圆心到离圆心最近的边
closest-corner:径向渐变的半径长度为从圆心到离圆心最近的角
farthest-side:径向渐变的半径长度为从圆心到离圆心最远的边
渐变的位置(值前需要添加 at)
center:设置中间为径向渐变圆心的纵坐标值(默认值)
top:设置顶部为径向渐变圆心的纵坐标值
bottom:设置底部为径向渐变圆心的纵坐标值
后续参数:渐变的起止颜色
3.1用法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.test-div {
margin-bottom: 10px;
width: 500px;
height: 60px;
line-height: 60px;
color: #fff;
}
.div1 {
background-image: radial-gradient(blue, red);
}
.div2 {
background-image: radial-gradient(circle, blue, red);
}
.div3 {
background-image: radial-gradient(circle closest-side, blue, red);
}
.div4 {
background-image: radial-gradient(ellipse closest-corner at center, blue, red);
}
</style>
</head>
<body>
<div class="test-div div1">background: linear-gradient(to right, blue, red);</div>
<div class="test-div div2">background: linear-gradient(to right, blue, red, yellow);</div>
<div class="test-div div3">background: linear-gradient(to bottom, blue, red, yellow);</div>
<div class="test-div div4">background: linear-gradient(45deg, blue, red, yellow);</div>
</body>
</html>
效果图
3.2浏览器支持
函数 | |||||
radial-gradient() | 26.0 | 10.0 | 16.0 | 6.1 | 12.1 |
4.conic-gradient()
conic-gradient()创建一个表示两种或多种颜色锥形渐变的图片
conic-gradient(angle position,color1,color2,…)
参数1:
渐变起始角度(值前需要添加 from)
中心位置 (值前需要添加 at)
center:设置中间为径向渐变圆心的纵坐标值(默认值)
top:设置顶部为径向渐变圆心的纵坐标值
bottom:设置底部为径向渐变圆心的纵坐标值
后续参数:渐变的起止颜色
4.1用法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.test-div {
margin-bottom: 10px;
width: 180px;
height: 180px;
line-height: 40px;
color: #fff;
}
.div1 {
background-image: conic-gradient(blue, red);
}
.div2 {
background-image: conic-gradient(from 45deg, blue, red);
}
.div3 {
background-image: conic-gradient(from 45deg at top, blue, red);
}
.div4 {
background-image: conic-gradient(red, magenta, blue, aqua, lime, yellow, red);
}
</style>
</head>
<body>
<div class="test-div div1">background-image: conic-gradient(blue, red); </div>
<div class="test-div div2">background-image: conic-gradient(from 45deg, blue, red);</div>
<div class="test-div div3">background-image: conic-gradient(from 45deg at top, blue, red);</div>
<div class="test-div div4">background-image: conic-gradient(red, magenta, blue, aqua, lime, yellow, red);</div>
</body>
</html>
效果图
4.2浏览器支持
函数 | |||||
conic-gradient() | 81.0 | – | – | 13.0 | 67.0 |
四、数学函数
1.calc()
calc()用于动态计算长度值
需要注意的是,运算符前后都需要保留一个空格,例如:width: calc(100% – 10px);
任何长度值都可以使用calc()函数进行计算;
calc()函数支持 “+”, “-“, “*”, “/” 运算;
calc()函数使用标准的数学运算优先级规则;
1.1用法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.test-div {
margin-bottom: 10px;
width: 200px;
height: 200px;
line-height: 40px;
color: #fff;
}
.div1 {
width: calc(200px + 100px);
height: calc(200px - 110px);
line-height: calc(200px - 170px);
background-color: red;
}
</style>
</head>
<body>
<div class="test-div div1">经计算样式值为:width:300px;height:90px;line-height:30px;</div>
</body>
</html>
效果图
1.2浏览器支持
函数 | |||||
calc() | 26.0 | 9.0 | 16.0 | 7.0 | 15.0 |
2.min()
min()比较数值的大小并取出最小的值来使用
2.1用法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.test-div {
margin-bottom: 10px;
width: 200px;
height: 200px;
line-height: 40px;
color: #fff;
}
.div1 {
width: min(200px, 100px);
background-color: red;
}
</style>
</head>
<body>
<div class="test-div div1">在200px和100px中选出最小的100px</div>
</body>
</html>
效果图
2.2浏览器支持
函数 | |||||
min() | 17.0 | 10.0 | 10.0 | 6.0 | 12.0 |
3.max()
min()比较数值的大小并取出最大的值来使用
3.1用法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.test-div {
margin-bottom: 10px;
width: 200px;
height: 200px;
line-height: 40px;
color: #fff;
}
.div1 {
width: max(200px, 100px);
background-color: red;
}
</style>
</head>
<body>
<div class="test-div div1">在200px和100px中选出最大的100px</div>
</body>
</html>
效果图
3.2浏览器支持
函数 | |||||
max() | 39.0 | 11.0 | 34.0 | 8.0 | 24.0 |
原文链接https://mp.weixin.qq.com/s/Qiik4udc3LYt61S-98UdXQ
今天的文章CSS函数(一)分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/26591.html