js窗口拖拽

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .box{position:absolute; left:100px; top:100px; padding:5px; width: 300px;height: 200px;background:#f0f3f9; font-size:12px; -moz-box-shadow:2px 2px 4px #666666; -webkit-box-shadow:2px 2px 4px #666666;}
        .bar{width:100%;height: 30px;background: #ccc; }
    </style>
</head>
<body>
    <div id="box" class="box"><div id="bar" class="bar">拖拽</div></div>

    <script src="d2.js" type="text/javascript"></script>
    <script type="text/javascript">
        var oBox = document.getElementById("box");
        var oBar = document.getElementById("bar");
        startDrag("bar", oBox,true,function(left,top){
            // console.log(left);
        });
    </script>
</body>
</html>
/**
 * 纯js实现多div拖拽
 * @param bar, 拖拽触柄
 * @param target, 可拖动窗口
 * @param inWindow, 为true时只能在屏幕范围内拖拽
 * @param callback, 拖拽时执行的回调函数。包含两个参数,target的left和top
 * @returns {*}
 * @private
 */
var startDrag = function(bar,target,inWindow,callback){
    (function(bar,target,inWindow,callback){
        var D = document,
              DB = document.body,
              params = {
            top: 0,
            left: 0,
            currentX: 0,
            currentY: 0
              };
        bar = (typeof bar == "string")?D.getElementById(bar):bar;
        target = (typeof target == "string")?D.getElementById(target):target;
        bar.style.cursor = "move";
        bindHandler(bar,"mousedown",function(e){
            e.preventDefault();
            if(!e){
                e = window.event;
                bar.onselectstart = function(){
                    return false;
                }
            }
            params.top = target.offsetTop;
            params.left = target.offsetLeft;
            params.currentX = e.clientX;
            params.currentY = e.clientY;
            var stopDrag = function(){
                removeHander(bar,"mousemove",beginDrag);
                removeHander(bar,"mouseup",stopDrag);
            };
            var beginDrag = function(e){
                var evt = e?e:window.event;
                var nowX = e.clientX,nowY = e.clientY;
                var disX = nowX - params.currentX,disY = nowY - params.currentY;
                var left = parseInt(params.left) + disX,top = parseInt(params.top) + disY;
                if(inWindow){
                    var h = window.innerHeight||document.documentElement.clientHeight||document.body.clientHeight;
                    var w = window.innerWidth||document.documentElement.clientWidth||document.body.clientWidth;
                    var maxTop = h - target.offsetHeight;
                    var maxLeft = w - target.offsetWidth;
                    if(left <= 0){
                        left = 0;
                    }
                    if(left >= maxLeft){
                        left = maxLeft;
                    }
                    if(top <= 0){
                        top = 0;
                    }
                    if(top >= maxTop){
                        top = maxTop;
                    }
                }
                target.style.left = left + "px";
                target.style.top = top + "px";
                if(typeof callback == "function"){
                    callback(left,top);
                }
            };
            bindHandler(bar,"mousemove",beginDrag);
            bindHandler(document,"mouseup",stopDrag);
        });


        function bindHandler(elem,type,hander){
            if(window.addEventListener){
                elem.addEventListener(type,hander,false);
            }else if(window.attachEvent){
                elem.attachEvent("on"+type,handler);
            }
        }
        function removeHander(elem,type,hander){
            if(window.removeEventListener){
                elem.removeEventListener(type,hander);
            }else if(window.detachEvent){
                ele.detachEvent("on"+type,hander);
            }
        }
    })(bar,target,inWindow,callback);
}

效果:
这里写图片描述
完整例子:http://pan.baidu.com/s/1jI2UjHG

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、下载 4使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、 4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.m或d论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 、1资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。、资源 5来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。、资 5源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值