bounty将在4天后过期。此问题的答案可获得+100声望奖励。COil希望奖励现有答案:您好,我添加了一条评论,请随时完成您的回答(如果可能的话)。
有很多scss的例子,但只有少数与CSS。有人知道一个简单的方法来动画一个圆圈倒计时与纯CSS。
olhwl3o21#
下面是一个简短的仅使用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); } }
<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>
如上所示,您可以使用变量控制大小和持续时间。
1条答案
按热度按时间olhwl3o21#
下面是一个简短的仅使用CSS的示例:
如上所示,您可以使用变量控制大小和持续时间。