计算鼠标在盒子内的坐标

Tutorial: DOM操作 Category: JS Published: 2026-04-07 13:58:26 Views: 20 Likes: 0 Comments: 0
<!DOCTYPE html>
<html lang="en">
  <head>
    <style>
      .box {
        width: 200px;
        height: 200px;
        background-color: pink;
        margin: 100px;
      }
    </style>
  </head>

  <body>
    <div class="box"></div>
    <script>
      // 我们在盒子内点击,  想要得到鼠标距离盒子左右的距离.
      // 首先得到鼠标在页面中的坐标( e.pageX, e.pageY)
      // 其次得到盒子在页面中的距离(box.offsetLeft, box.offsetTop)
      // 用鼠标距离页面的坐标减去盒子在页面中的距离,  得到 鼠标在盒子内的坐标
      var box = document.querySelector(".box");

      box.addEventListener("mousemove", function (e) {
        console.log(e.pageX);
        console.log(e.pageY);
        // console.log(box.offsetLeft);
        var x = e.pageX - this.offsetLeft;
        var y = e.pageY - this.offsetTop;
        this.innerHTML = "x坐标是" + x + " y坐标是" + y;
      });
    </script>
  </body>
</html>