jQuery实现的鼠标拖动浮层功能示例【拖动div等任

拖动浮层(div等任何标签)

之前项目做到一个弹出层需要一个拖动功能,上网上查了资料,发现很多方法,但是感觉都很繁琐,有的甚至没看懂。看了几个方法后发现基本上都是使用mousedown、mousemove和mouseup这三个函数来写的,然后就自己写了个移动div的方法。

先用mousedown来判断是否要开启移动,然后通过mousemove来获得移动的距离,实现移动;最后通过mouseup事件来判断移动结束了。

完整代码实例:

<html> <head> <meta charset="utf-8"></meta> <title>Drag Div</title> <script src="https://libs.baidu.com/jquery/2.0.3/jquery.min.js"></script> </head> <body> <div> <div></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>

这里使用在线HTML/CSS/JavaScript代码运行工具测试上述代码,可获得如下运行效果:

jQuery实现的鼠标拖动浮层功能示例【拖动div等任

更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery拖拽特效与技巧总结》、《jQuery常用插件及用法总结》、《jquery中Ajax用法总结》、《jQuery表格(table)操作技巧汇总》、《jQuery扩展技巧总结》、《jQuery常见经典特效汇总》、《jQuery动画与特效用法总结》及《jquery选择器用法总结

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/c1bc646d662944b7232b1ac6cfca87a8.html