拖动浮层(div等任何标签)
2016-10-13 15:54
148 查看
拖动浮层(div等任何标签)
之前项目做到一个弹出层需要一个拖动功能,上网上查了资料,发现很多方法,但是感觉都很繁琐,有的甚至没看懂。看了几个方法后发现基本上都是使用mousedown、mousemove和mouseup这三个函数来写的,然后就自己写了个移动div的方法。
先用mousedown来判断是否要开启移动,然后通过mousemove来获得移动的距离,实现移动;最后通过mouseup事件来判断移动结束了。
完整代码实例:<html> <head> <meta charset="utf-8"></meta> <title>Drag Div</title> <script src="jquery-1.12.1.js"></script> </head> <body> <div id="moveDiv" style="width:300px;height:300px;background-color:red;position:absolute;"> <div id="moveBar" style="background-color:green;height:30px;cursor: move;"></div> </div> <script type="text/javascript"> var dragJob=false; $(document).on("mousedown", '#moveBar', function (e) { dragJob = true; }); document.onmousemove = function (e) { if (dragJob) { var e = e || window.event; var height = $(document.body).height(); var width = $(window).width(); var widthJob = $("#moveDiv").width(); var heightJob = $("#moveDiv").height(); var left = e.clientX - widthJob / 2; var top = e.clientY - 18 + $(document).scrollTop(); if (top >= 0 && top < height - heightJob) { $("#moveDiv").css("top", top); } if (left >= 0 && left < width - widthJob) { $("#moveDiv").css("left", left); } return false; } }; $(document).mouseup(function (e) { dragJob = false; }); </script> </body> </html>
相关文章推荐
- js 鼠标拖动对象 可让任何div实现拖动效果
- HTML 可拖动div标签
- 鼠标拖动层(可任意绑定DIV标签)(实现方法二)
- 鼠标拖动层(可任意绑定DIV标签)(实现方法一)
- 鼠标拖动层(可任意绑定DIV标签)的两种实现方法
- js 鼠标拖动对象 可让任何div实现拖动效果
- 拖动数据到div
- DIV/CSS+Jquery自己写的分页标签
- div 拖动3(2)
- UEditor写入源代码后,格式乱掉。少标签,div不见,多空行等等错误!(已解决)
- 标签页效果 ul,li,div。标签与div的互动
- 如何让DIV可编辑、可拖动
- jquery-ui中div拖动出现辅助线方便对齐
- 修改div内A标签的href值
- DIV标签设置浮动后,对下一个DIV标签width的影响
- js 下div 拖动效果
- 拖动DIV到指定的区域,不是该区域不允许拖动
- HTML中div和span两个标签的区别
- 代码短小的js div层拖动实现代码[兼容IE与Firefox]
- HTML第十二天 节标签 div span