javascript - onmousemove问题?
怪我咯
怪我咯 2017-04-11 11:11:35
[JavaScript讨论组]

为什么设置document的onmousemove事件,拖拽时不会有问题,
而设置box的onmousemove事件拖拽时就会有问题呢?





    
    完美拖拽
    
    


点击回放拖动轨迹

Drag:false

offsetTop:231

offsetLeft:533

怪我咯
怪我咯

走同样的路,发现不同的人生

全部回复(2)
天蓬老师

最好是委托在document上,委托在box上的话鼠标很容易脱离当前元素,导致移动失败

阿神

实验一次之后,问题出现在你的样式上。

#box{position:absolute;width:300px;height:150px;background:#333;border:2px solid #ccc;margin:-75px 0 0 -150px;}

删除这句话之后改为box虽然还是有些小BUG,但是基本上已经有了初步的效果。

代码改进:

  window.onload = function(){
            var box = document.getElementById("box");
            var onoff = false;
            var disx;
            var disy;
            box.onmousedown = function(ev){
                disx = ev.clientX - this.offsetLeft;
                disy = ev.clientY - this.offsetTop;
                onoff = true;
            };
            box.onmousemove = function(ev){
              if(onoff){
                var l = ev.clientX - disx ;
                var t = ev.clientY - disy;
                box.style.left = l + "px";
                box.style.top = t + "px";
              }
            };
            box.onmouseup = function(){
                onoff = false;
            };
    };

但是这样依然有些问题,如果鼠标在拖拽过程鼠标离开了box,那么就会出现BUG。
所以讲onmousemove和onmouseup设为document更好一些。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号