JavaScript实现拖拽盒子效果
本文实例为大家分享了JavaScript实现拖拽盒子效果的具体代码,供大家参考,具体内容如下
实现效果
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.让拖拽盒子居中显示:50%; left: 50%;
margin-left :-155px; margin-:-155px;
( margin-left: -(盒子宽度的一半); 这里盒子宽度300px边框为5px,总宽度310px,
所以设置-155px, margin-:-(盒子高度的一半),和宽度同理)
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; :50%; left:50%; margin-left: -155px; margin-: -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; :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. = 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>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程