JavaScript实现鼠标控制自由移动的窗口
作者:妄痴梦中
这篇文章主要为大家详细介绍了JavaScript实现鼠标控制自由移动的窗口,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了JavaScript实现鼠标控制自由窗口的具体代码,供大家参考,具体内容如下
代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>用鼠标移动的窗口</title> <style> .mainDiv { width: 350px; height: 200px; border: 2px black solid; position: absolute; } .titleDiv { width: 350px; height: 30px; background-color: YellowGreen ; text-align: center; line-height: 30px; } .contentDiv { width: 350px; height: 170px; background-color: SandyBrown ; text-align: center; } </style> </head> <body> <!--onmousedown:事件会在鼠标按键被按下时发生; onmousemove:事件会在鼠标指针移到指定的对象时发生--> <div class="mainDiv" id="mainDiv" style="top: 20px;left: 20px"> <div class="titleDiv" id="titleDiv" onmousedown="mouseDown()" onmouseup="mouseUp()"> 标题栏 </div> <div class="contentDiv"> 《鼠标可控的自由窗口》<br> 注意:没有给mainDiv设置position为absolute前不能移动 </div> </div> <script> var dx; var dy; var mainDivObj = null; var titleDivObj = null; /** * 鼠标按下函数,当鼠标按下时执行该函数 */ function mouseDown() { //获得鼠标的键值,0是鼠标左键;1是鼠标滚轴键;2是鼠标右键 if (event.button == 0) { mainDivObj = document.getElementById("mainDiv"); titleDivObj = document.getElementById("titleDiv"); //设置鼠标样式 titleDivObj.style.cursor = "move"; //设置主div的阴影样式 mainDivObj.style.boxShadow = "0px 0px 10px #000"; //获得鼠标当前坐标 let x = event.x; let y = event.y; dx = x - parseInt(mainDivObj.style.left); dy = y - parseInt(mainDivObj.style.top); } } //鼠标移动的时候调用 document.onmousemove = mouseMove; /** * 按下鼠标后移动函数,当鼠标移动是执行该函数,移动div */ function mouseMove() { if (mainDivObj != null) { //获得鼠标当前移动的坐标位置 let x = event.x;//鼠标移动的x轴的坐标 let y = event.y;//鼠标移动的y轴的坐标 //计算div移动后的left与top的距离 //使用当前坐标减去鼠标在div中的位置与div左边与顶端的距离 let left = x - dx; let top = y - dy; //设置div新的坐标位置 mainDivObj.style.left = left + "px"; mainDivObj.style.top = top + "px"; } } /** * 鼠标松开函数,当鼠标松开时执行该函数 */ function mouseUp() { if (mainDivObj != null) { dx = null; dy = null; //设置div的阴影样式 mainDivObj.style.boxShadow="none"; mainDivObj = null; titleDivObj.style.cursor="pointer"; titleDivObj = null; } } </script> </body> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。