js实现滑动进度条

js实现滑动进度条js实现滑动进度条

效果图

image.png

完整代码

<!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>
    <style> section { 
      width: 500px; height: 30px; background-color: red; display: flex; justify-content: space-around; align-items: center; } div { 
      position: relative; width: 90%; height: 50%; background-color: #ccc; } .jd { 
      position: absolute; top: -104%; height: 100%; background-color: green; } .ball { 
      position: absolute; top: -120%; left: -10px; height: 20px; width: 20px; border-radius: 50%; background-image: radial-gradient(circle, #ccc, white, #ccc); } </style>
  </head>
  <body>
    <h2>滑动滚动条</h2>
    <section>
      <div>
        <p class="jd"></p>
        <p class="ball"></p>
      </div>
    </section>

    <script> let section = document.querySelector("section"); let div = document.querySelector("div"); let jd = document.querySelector(".jd"); let ball = document.querySelector(".ball"); function xj(e) { 
      ///获取鼠标坐标 let x = e.pageX; let y = e.pageY; //获取父盒子左和上面距离 let sx = div.offsetLeft; let sy = div.offsetTop; //获取小球在盒子内的坐标 let bx = x - sx; let by = y - sy; // console.log(bx, by); //因为是进度条,top值不用改变,只需要bx就可以了 //获取小球中心点 let ce = bx - ball.offsetWidth / 2; //做边界判断 if (ce < -10) { 
      return; } console.log(ce); //获取div的长度,超出长度小球不再前进 let divw = div.offsetWidth; console.log(divw); if (ce + 10 <= divw) { 
      //更改小球left值 ball.style.left = ce + "px"; //更改盒子宽 jd.style.width = ce + 15 + "px"; } } //鼠标按下触发鼠标的move事件 section.addEventListener("mousedown", function () { 
      document.addEventListener("mousemove", xj); }); //松开鼠标移除事件 document.addEventListener("mouseup", function () { 
      document.removeEventListener("mousemove", xj); }); </script>
  </body>
</html>

今天的文章js实现滑动进度条分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/29531.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注