遮罩层圆环进度条(窃)

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <style>
    .circle {
      width: 300px;
      height: 300px;
      background: conic-gradient(
        #179067,
        #62e317,
        #d7f10f,
        #ffc403,
        #fcc202,
        #ff7327,
        #ff7327,
        #ff5800,
        #ff5900,
        #f64302,
        #ff0000,
        #ff0000
      );
      border-radius: 50%;
      position: relative;
    }

    #progress-circle circle {
      stroke-dasharray: 880;
      stroke: #f2f2f2;
      transition: all 2s;
    }

    #progress-circle {
      transform: rotate(-90deg);
    }

    .circle-mask {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      z-index: 2;
      width: 260px;
      height: 260px;
      background: #fff;
      border-radius: 50%;
    }
  </style>

  <body>
    <div class="circle">
      <svg id="progress-circle" width="300" height="300">
        <circle
          r="140"
          cx="150"
          cy="150"
          stroke-width="21"
          fill="transparent"
        />
      </svg>
      <div class="circle-mask"></div>
    </div>
  </body>
  <script>
    const circle = document.querySelector("#progress-circle circle");
    const radius = circle.r.baseVal.value;
    const circumference = radius * 2 * Math.PI;
    function setProgress(percent) {
      const progress = circumference - (percent / 100) * circumference;
      circle.style.strokeDashoffset = -progress;
    }
    let prog = 20;
    let val = 30;
    setTimeout(() => {
      setProgress(val); //设置初始进度
    }, 2000);
  </script>
</html>

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值