And*_*Wie 4 css timer progress css-animations
scss 示例有很多,但使用 CSS 的却很少。有人知道一种用纯 CSS 制作的圆形倒计时动画的简单方法。
Sim*_*bus 16
这是一个简单而简短的纯 CSS 示例:
.timer {
background: -webkit-linear-gradient(left, skyBlue 50%, #eee 50%);
border-radius: 100%;
height: calc(var(--size) * 1px);
width: calc(var(--size) * 1px);
position: relative;
-webkit-animation: time calc(var(--duration) * 1s) steps(1000, start) infinite;
-webkit-mask: radial-gradient(transparent 50%,#000 50%);
mask: radial-gradient(transparent 50%,#000 50%);
}
.mask {
border-radius: 100% 0 0 100% / 50% 0 0 50%;
height: 100%;
left: 0;
position: absolute;
top: 0;
width: 50%;
-webkit-animation: mask calc(var(--duration) * 1s) steps(500, start) infinite;
-webkit-transform-origin: 100% 50%;
}
@-webkit-keyframes time {
100% {
-webkit-transform: rotate(360deg);
}
}
@-webkit-keyframes mask {
0% {
background: #eee;
-webkit-transform: rotate(0deg);
}
50% {
background: #eee;
-webkit-transform: rotate(-180deg);
}
50.01% {
background: skyBlue;
-webkit-transform: rotate(0deg);
}
100% {
background: skyBlue;
-webkit-transform: rotate(-180deg);
}
}Run Code Online (Sandbox Code Playgroud)
<div class="timer" style="--duration: 3;--size: 30;">
<div class="mask"></div>
</div>
<div class="timer" style="--duration: 10;--size: 100;">
<div class="mask"></div>
</div>Run Code Online (Sandbox Code Playgroud)
如上所示,您可以使用变量控制大小和持续时间。
编辑:
要回答 @COil 的评论,要求文本倒计时:感谢这些问题的答案:/sf/answers/3752178811/和/sf/answers/2812580291/ 我能够拼凑出一个解决方案,但它非常静态,因为它需要最少 X 个动画步骤(X 是以秒为单位的持续时间)才能以步骤 1 显示数字:
.countdown:after {
counter-reset: duration calc(var(--duration) * 1.0);
content: counter(duration);
animation: spin calc(var(--duration) * 1s) infinite;
}
@keyframes spin {
1% {
counter-reset: duration calc(var(--duration) * 1.0);
content: counter(duration);
}
11% {
counter-reset: duration calc(var(--duration) * 0.9);
content: counter(duration);
}
21% {
counter-reset: duration calc(var(--duration) * 0.8);
content: counter(duration);
}
31% {
counter-reset: duration calc(var(--duration) * 0.7);
content: counter(duration);
}
41% {
counter-reset: duration calc(var(--duration) * 0.6);
content: counter(duration);
}
51% {
counter-reset: duration calc(var(--duration) * 0.5);
content: counter(duration);
}
61% {
counter-reset: duration calc(var(--duration) * 0.4);
content: counter(duration);
}
71% {
counter-reset: duration calc(var(--duration) * 0.3);
content: counter(duration);
}
81% {
counter-reset: duration calc(var(--duration) * 0.2);
content: counter(duration);
}
91% {
counter-reset: duration calc(var(--duration) * 0.1);
content: counter(duration);
}
100% {
counter-reset: duration calc(var(--duration) * 0);
content: counter(duration);
}
}Run Code Online (Sandbox Code Playgroud)
<p class="countdown" style="--duration: 10;">
</p>Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
7994 次 |
| 最近记录: |