用JavaScript实现拖拽盒子

186 阅读1分钟

实现效果:

    1.单击关闭,关闭盒子
    2.点击左上方‘点击注册’,打开盒子
    3.鼠标放在盒子上方蓝色区域显示十字
    4.点击鼠标不松开就可移动盒子
    5.松开鼠标图片暂停

在这里插入图片描述

实现步骤:

   1.在页面最上方设置一个盒子,里面有一个超链接,
       超链接里面设置href="javascript:void(0);",再点击时不打开网页。
   2.再设置一个可以拖拽的盒子,盒子嵌套一个蓝色盒子为的最上方的蓝色区域,
       蓝色盒子里面两个span标签,里面写‘关闭’和‘可拖拽’。
   3.给‘关闭’的盒子注册点击事件,点击后,拖拽盒子样式为none,(不显示)
        给最上方的超链接设置点击事件,点击后,拖拽盒子样式为block,(显示)
   4.给上方蓝色盒子设置onmousedown(鼠标点击事件),同时获取鼠标点击位置
      离拖拽盒子的距离,为mouseLeft和mouseTop
    5.给页面(document)设置onmousemove事件让鼠标的位置分别减去mouseLeft和
        mouseTop,得到盒子左上角随鼠标移动的坐标,再将坐标赋值给拖拽盒子
    6.最后设置onmouseup事件,鼠标松开时页面不移动。即document.onmousemove = 
       null

实现细节:

     1.让拖拽盒子居中显示:top:50%;  left: 50%;  
       margin-left :-155px;  margin-top:-155px;
      ( margin-left: -(盒子宽度的一半); 这里盒子宽度300px边框为5px,总宽度310px,
      所以设置-155pxmargin-top:-(盒子高度的一半),和宽度同理)
     2,var evt = event || window.event;兼容性写法。

代码:

<!DOCTYPE html>
<html>
<head>
	<title>拖拽盒子</title>
	<style type="text/css">
	*{
		margin:0px;
		padding:0px;
	}
		.dropBox{
			width:300px;
			height:300px;
            top:50%;
            left:50%;
            margin-left: -155px;
            margin-top: -155px;
            display: block;
			border: 5px solid #aaa;
			position: absolute;
		}

		.nav{
			width: 100%;
			height:30px;
			background-color: blue;
			opacity: 0.6;
		}
		.nav a{
			font-size:15px;
			color:white;
		}
		.dropBox .box{
			width:300px;
			height:30px;
			position: absolute;
			left:0px;
			top:0px;
			background-color: darkblue;
			opacity: 0.8;
			cursor:move;
		}
		.close{
			float: right;
			color:white;
			font-size: 15px;
			cursor: pointer;
		}
		.move{
			color:white;
			font-size: 15px;
		}
	</style>
      <script type="text/javascript">
      	function $(id){
      		return document.getElementById(id);
      	}
      	window.onload = function(){
      		var register = $('register');
      		var dropBox = $('dropDiv');
      		var box = $('box');
      		var box2 = $('box2');
      		box2.onclick = function(){
      			dropBox.style.display = 'none';
      		}
      		register.onclick = function(){
      			dropBox.style.display = 'block';
      		}
      			box.onmousedown = function(event){
      				var evt = event || window.event;
      			    var mouseLeft = evt.clientX - dropBox.offsetLeft;
      			    var mouseTop = evt.clientY - dropBox.offsetTop;
      			    document.onmousemove = function(event){
      			    	var evt = event || window.event;
      			    	var x = evt.clientX -  mouseLeft;
      			    	var y = evt.clientY - mouseTop;
      			    	dropBox.style.left = x + 155 + 'px';
      			    	dropBox.style.top = y + 155 + 'px';
      			    }
      			    document.onmouseup = function (){
    				document.onmousemove = null;
    		   }
      	   }

      	}



      </script>
</head>
<body>
	 <div class="nav">
	 	<a href="javascript:void(0);" id="register">点击注册</a>
	 </div>
	 <div class="dropBox" id="dropDiv">
	 	<div class="box" id="box">
	 		<span class="move">注册信息(可以拖拽)</span>
	 		<span class="close" id="box2">【关闭】</span>
	 	</div>
	 	
	 </div>
</body>
</html>