前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >当鼠标按下时拖动元素,简单的JS实现

当鼠标按下时拖动元素,简单的JS实现

作者头像
房东的狗丶
发布2023-02-17 13:46:00
发布2023-02-17 13:46:00
3.8K00
代码可运行
举报
文章被收录于专栏:友人a的笔记丶友人a的笔记丶
运行总次数:0
代码可运行

记录

监听需要移动元素的键盘按下、松开事件和文档对象的鼠标移动事件,

通过一个布尔值作为是否移动的标志,按下时为TRUE,代表跟随移动,鼠标松开为FALSE,代表不跟随移动,鼠标移动时改变元素偏移量。

代码语言:javascript
代码运行次数:0
运行
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>物体跟着鼠标移动</title>
</head>
<style>
    .box {
        width: 100px;
        height: 100px;
        background-color: red;
        position: absolute;
        left: 0;
        top: 0;
    }
</style>
<body>
    <div class="box"></div>
</body>
<script>
     var boxDom = document.querySelector(".box");
     var flag=false,offX,offY;
     boxDom.onmousedown=function (){
         let evt = event || window.event;
         offX=evt.clientX-window.getComputedStyle(boxDom,null)["left"].slice(0,-2);
         offY=evt.clientY-window.getComputedStyle(boxDom,null)["top"].slice(0,-2);
         flag=true;
     }
     boxDom.onmouseup=function (){
         flag=false;
     }
     document.onmousemove = function (event) {
         if(flag){
             let evt = event || window.event;
             console.log(evt.clientX -offX);
             console.log(evt.clientY - offY);
             boxDom.style.left = evt.clientX -offX + "px";
             boxDom.style.top = evt.clientY - offY + "px";
         }
     }
 </script>
 </html>
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-07-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 记录
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档