CSS3实现圆形进度条效果

今天早上在群里看到有同学问如何用 CSS3 实现以下效果?

设计效果图

一开始我觉得 CSS3 搞不出来这种效果的吧,主要是白色透明那个地方,后来灵机一动想到了渐变至透明色(不考虑兼容性的情况)应该是可以做出来的。如果你对 CSS3 比较熟悉的话,那么你应该对渐变效果 linear-gradient 也不陌生,不了解的同学可以去查阅 文档

首先我们对这个结构进行一下拆分,看下图所示:

结构拆分

有的同学一看到这张图就已经知道该怎么做了,对,就是用 border-radius + 遮罩。先用 border-radius 做一个圆出来,再加上线性渐变色,中间部分用伪类也做一个圆,定位过去盖上,于是就有了外面的空心圆,即下图所示:

圆

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
.box1 {
width: 100px;
height: 100px;
position: relative;
border-radius: 50%;
background-image: linear-gradient(
60deg,
#f79533,
#f37055,
#ef4e7b,
#a166ab,
#5073b8,
#1098ad,
#07b39b,
#6fba82);
background-image: linear-gradient(
60deg,
#f79533,
#f37055,
#ef4e7b,
#a166ab,
#5073b8,
#1098ad,
#07b39b,
#6fba82);
}
.box1:after {
width: 90px;
height: 90px;
position: absolute;
top: 5px;
left: 5px;
background-color: #fff;
content: ' ';
border-radius: 50%;
}
.box1:before {
width: 50px;
height: 50px;
position: absolute;
top: 50px;
left: 50px;
content: ' ';
background-image: -webkit-linear-gradient(right top, white 60%, transparent);
background-image:linear-gradient(right top, white 60%, transparent);
}

接下来就是最重要的一步了,用线性渐变画出遮罩层,直接上代码吧:

1
2
3
4
5
6
7
8
9
10
.box1:before {
width: 50px;
height: 50px;
position: absolute;
top: 50px;
left: 50px;
content: ' ';
background-image: -webkit-linear-gradient(right top, white 60%, transparent);
background-image:linear-gradient(right top, white 60%, transparent);
}

这样一来我们就实现了上面的效果,完整代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
.box1 {
width: 100px;
height: 100px;
position: relative;
border-radius: 50%;
background-image: linear-gradient(
60deg,
#f79533,
#f37055,
#ef4e7b,
#a166ab,
#5073b8,
#1098ad,
#07b39b,
#6fba82);
background-image: linear-gradient(
60deg,
#f79533,
#f37055,
#ef4e7b,
#a166ab,
#5073b8,
#1098ad,
#07b39b,
#6fba82);
}
.box1:after {
width: 90px;
height: 90px;
position: absolute;
top: 5px;
left: 5px;
background-color: #fff;
content: ' ';
border-radius: 50%;
}
.box1:before {
width: 50px;
height: 50px;
position: absolute;
top: 50px;
left: 50px;
content: ' ';
background-image: -webkit-linear-gradient(right top, white 60%, transparent);
background-image:linear-gradient(right top, white 60%, transparent);
}
</style>
</head>
<body>
<div class="box1">
</div>
</body>
</html>

最终效果图:
最终效果图