27.js实现鼠标拖拽

e.offsetX是鼠标距离准确事件源的左上角距离

e.clientX是鼠标距离浏览器可视窗口左上角的距离

e.pageX是鼠标距离文档左上角的距离

/*

当鼠标点击div时开始挪动,当鼠标抬起,div静止------事件源是div

当鼠标点击后,鼠标在移动------事件源是document

事件类型------鼠标事件

事件处理函数------要做的式是改变div的位置

*/

javascript 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }

        div {
            width: 200px;
            height: 200px;
            background-color: pink;
            position: absolute;
            left: 0;
            top: 0;
        }
    </style>
</head>

<body>
    <div>

    </div>
    <script>
        var box = document.querySelector('div')

        
        var startX=0    //记录鼠标初始距离div的X位置
        var startY=0
        var flag = false    //当点击div时移动div位置,否则不移动
        box.onmousedown = function (e) {
            startX = e.offsetX
            startY = e.offsetY
            flag = true
        }
        document.addEventListener('mousemove', function (e) {
            if (flag == false) {
                return   
            }
            x = e.clientX - startX;
            y = e.clientY - startY;
            if (x <= 0) {
               x = 0;
            }
            if (y <= 0) {
               y = 0;
            }
            box.style.left = x + "px";
            box.style.top = y + "px";
               
        })
        box.onmouseup = function (e) {
            flag = false   //当抬起鼠标不移动
            // console.log('鼠标抬起的位置', e.offsetX, e.offsetY)
        }

    </script>
</body>

</html>

优化:

x最大值应该是:

相关推荐
Ten peaches4 分钟前
Selenium-Java版(环境安装)
java·前端·selenium·自动化
Enti7c6 分钟前
BOM知识点
javascript
心.c16 分钟前
vue3大事件项目
前端·javascript·vue.js
姜 萌@cnblogs26 分钟前
【实战】深入浅出 Rust 并发:RwLock 与 Mutex 在 Tauri 项目中的实践
前端·ai·rust·tauri
蓝天白云下遛狗33 分钟前
google-Chrome常用插件
前端·chrome
多多*1 小时前
Spring之Bean的初始化 Bean的生命周期 全站式解析
java·开发语言·前端·数据库·后端·spring·servlet
linweidong1 小时前
在企业级应用中,你如何构建一个全面的前端测试策略,包括单元测试、集成测试、端到端测试
前端·selenium·单元测试·集成测试·前端面试·mocha·前端面经
满怀10152 小时前
【HTML 全栈进阶】从语义化到现代 Web 开发实战
前端·html
繁依Fanyi2 小时前
用 UniApp 构建习惯打卡 App —— HabitLoop 开发记
javascript·uni-app·codebuddy首席试玩官
东锋1.32 小时前
前端动画库 Anime.js 的V4 版本,兼容 Vue、React
前端·javascript·vue.js