JavaScript实现拖拽功能


Posted in Javascript onFebruary 11, 2020

本文实例为大家分享了JavaScript实现拖拽功能的具体代码,供大家参考,具体内容如下

盒子拖拽—运用到的有onmousedown事件,onmousemove事件以及onmouseup事件

1、当鼠标点击下去的时候我们需要获取鼠标所在位置的横纵坐标,然后获取盒子的离页面的横纵方向的距离
2、计算出鼠标相对盒子的距离
3、当鼠标移动的时候,获取鼠标移动的距离,在永鼠标此刻的位置减去鼠标相对盒子的距离,获得的是盒子此刻的坐标位置
4、将这个位置赋值给盒子
5、鼠标抬起,清除鼠标移动事件;

代码:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <title>鼠标拖拽</title>
 <style>
  .box{
   background-color: pink;
   width:200px;
   height:200px;
   border-radius: 50%;
   position: absolute;
   top:20px;
   left:100px;
  }
 </style>
</head>
<body>
 <div class="box">

 </div>
 <script>
  window.onload = function(){
   var box = document.getElementsByClassName('box')[0];
   function drag (ele){
    ele.onmousedown = function(e){
     var e = e || window.event; 
     //此处是为了兼容IE,因为IE中事件对象是作为全局对象( window.event )存在的;
     var pageX = e.pageX || e.clientX + document.documentElement.scrollLeft;
     var pageY = e.pageY || e.clientY + document.documentElement.scrollTop;
     //获取鼠标相对盒子的位置;
     var boxX = pageX - box.offsetLeft;
     var boxY = pageY - box.offsetTop;
     document.onmousemove = function(e){
      var e = e || window.event;
      var pageX = e.pageX || e.clientX + document.documentElement.scrollLeft;
      var pageY = e.pageY || e.clientY + document.documentElement.scrollTop;
      //将鼠标当前的坐标值减去鼠标相对盒子的位置,得到盒子当时的位置并将其赋值给盒子,实现移动效果
      box.style.left = pageX - boxX +'px';
      box.style.top = pageY - boxY + 'px';
     }
    };
    document.onmouseup = function () {
     //清除盒子的移动事件;
     document.onmousemove = null;
    };
   } ;
   drag(box)
  }
 </script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
IE6浏览器下resize事件被执行了多次解决方法
Dec 11 Javascript
基于pthread_create,readlink,getpid等函数的学习与总结
Jul 17 Javascript
jquery ajax,ashx,json的用法总结
Feb 12 Javascript
详谈jQuery中的this和$(this)
Nov 13 Javascript
使用HTML+CSS+JS制作简单的网页菜单界面
Jul 27 Javascript
Ionic快速安装教程
Jun 03 Javascript
原生javascript移动端滑动banner效果
Mar 10 Javascript
使用vue-cli+webpack搭建vue开发环境的方法
Dec 22 Javascript
详解Chai.js断言库API中文文档
Jan 31 Javascript
微信小程序实现九宫格抽奖
Apr 15 Javascript
node中使用log4js4.x版本记录日志的方法
Aug 20 Javascript
vant-ui框架的一个bug(解决切换后onload不触发)
Nov 11 Javascript
node.js中 mysql 增删改查操作及async,await处理实例分析
Feb 11 #Javascript
基于Angular 8和Bootstrap 4实现动态主题切换的示例代码
Feb 11 #Javascript
原生js实现点击轮播切换图片
Feb 11 #Javascript
node.js中process进程的概念和child_process子进程模块的使用方法示例
Feb 11 #Javascript
小程序如何定位所在城市及发起周边搜索
Feb 11 #Javascript
JS+DIV实现拖动效果
Feb 11 #Javascript
vue项目中使用particles实现粒子背景效果及遇到的坑(按钮没有点击响应)
Feb 11 #Javascript
You might like
PHP也可以?成Shell Script
2006/10/09 PHP
桌面中心(四)数据显示
2006/10/09 PHP
php扩展ZF――Validate扩展
2008/01/10 PHP
纯php打造的tab选项卡效果代码(不用js)
2010/12/29 PHP
PHP将身份证正反面两张照片合成一张图片的代码
2017/04/08 PHP
三个思路解决laravel上传文件报错:413 Request Entity Too Large问题
2017/11/13 PHP
php-fpm服务启动脚本的方法
2018/04/27 PHP
Laravel框架路由设置与使用示例
2018/06/12 PHP
HTTP 304错误的详细讲解
2013/11/13 Javascript
jquery果冻抖动效果实现方法
2015/01/15 Javascript
jQuery构造函数init参数分析
2015/05/13 Javascript
javacript获取当前屏幕大小
2016/06/04 Javascript
微信小程序 页面传参实例详解
2016/11/16 Javascript
微信小程序 登录的简单实现
2017/04/19 Javascript
详解Vue2中组件间通信的解决全方案
2017/07/28 Javascript
async/await地狱该如何避免详解
2018/05/10 Javascript
微信小程序解除10个请求并发限制
2018/12/18 Javascript
微信小程序左右滚动公告栏效果代码实例
2019/09/16 Javascript
ElementUI中el-tree节点的操作的实现
2020/02/27 Javascript
利用原生JS实现欢乐水果机小游戏
2020/04/23 Javascript
Element Popover 弹出框的使用示例
2020/07/26 Javascript
用javascript实现倒计时效果
2021/02/09 Javascript
Python中使用MELIAE分析程序内存占用实例
2015/02/18 Python
Python获取文件所在目录和文件名的方法
2017/01/12 Python
pandas 使用均值填充缺失值列的小技巧分享
2019/07/04 Python
python网络爬虫实现发送短信验证码的方法
2021/02/25 Python
一款纯css3实现的动画加载导航
2014/10/08 HTML / CSS
HTML5中判断用户是否正在浏览页面的方法
2014/05/03 HTML / CSS
database面试题
2013/03/28 面试题
Linux内核产生并发的原因
2016/11/08 面试题
成人高等教育毕业生自我鉴定
2013/10/22 职场文书
上课看小说检讨书
2014/02/22 职场文书
2014年妇幼保健工作总结
2014/12/08 职场文书
扬州个园导游词
2015/02/06 职场文书
导游词之京东大峡谷旅游区
2019/10/29 职场文书
mysql字段为NULL索引是否会失效实例详解
2022/05/30 MySQL