纯js拖拽参考

复制代码
function myDrag(obj){
    obj.onmousedown=function(e){
        var e=e||window.event;
        var diffX=e.clientX-this.offsetLeft;
        var diffY=e.clientY-this.offsetTop;
        document.onmousemove=function(e){
            var e=e||window.event;
            var left=e.clientX-diffX;
            var top=e.clientY-diffY;
            var leftMax=document.documentElement.clientWidth-obj.offsetWidth;
            var topMax=document.documentElement.clientHeight-obj.offsetHeight;
            if(left<0){
                left=0;
            }else if(left>leftMax){
                left=leftMax;
            }
            if(top<-20){
                 top=-20;
            }else if(top>topMax){
                top=topMax;
            }
            obj.style.left=left+"px";
            obj.style.top=top+"px";
        }
        document.onmouseup=function(){
        document.onmousemove=null;
        }
    }
}
复制代码

 

posted @   H&K  阅读(221)  评论(0编辑  收藏  举报
编辑推荐:
· 继承的思维:从思维模式到架构设计的深度解析
· 如何在 .NET 中 使用 ANTLR4
· 后端思维之高并发处理方案
· 理解Rust引用及其生命周期标识(下)
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
阅读排行:
· 当职场成战场:降职、阴谋与一场硬碰硬的抗争
· 用99元买的服务器搭一套CI/CD系统
· 35岁程序员的中年求职记:四次碰壁后的深度反思
· Excel百万数据如何快速导入?
· ShadowSql之.net sql拼写神器
点击右上角即可分享
微信分享提示