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 相关文章推荐
URL地址中的#符号使用说明
Feb 12 Javascript
纯javascript实现简单下拉刷新功能
Mar 13 Javascript
在线所见即所得HTML编辑器的实现原理浅析
Apr 25 Javascript
javascript嵌套函数和在函数内调用外部函数的区别分析
Jan 31 Javascript
JS代码防止SQL注入的方法(超简单)
Apr 12 Javascript
深入理解JavaScript中的call、apply、bind方法的区别
May 30 Javascript
如何获取元素的最终background-color
Feb 06 Javascript
jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能实例讲解一
May 26 jQuery
微信小程序实现分享到朋友圈功能
Jul 19 Javascript
微信小程序自定义弹窗滚动与页面滚动冲突的解决方法
Jul 16 Javascript
JavaScript 引用类型实例详解【数组、对象、严格模式等】
May 13 Javascript
三步搞定:Vue.js调用Android原生操作
Sep 07 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
phpmyadmin的#1251问题
2006/11/25 PHP
ThinkPHP提示错误Fatal error: Allowed memory size的解决方法
2015/02/12 PHP
php读取出一个文件夹及其子文件夹下所有文件的方法示例
2017/06/15 PHP
Thinkphp3.2简单解决多文件上传只上传一张的问题
2017/09/26 PHP
Laravel5.1 框架路由基础详解
2020/01/04 PHP
js 图片等比例缩放代码
2010/05/13 Javascript
js iframe跨域访问(同主域/非同主域)分别深入介绍
2013/01/24 Javascript
为jquery的ajaxfileupload增加附加参数的方法
2014/03/04 Javascript
JavaScript数组随机排列实现随机洗牌功能
2015/03/19 Javascript
JavaScript利用HTML DOM进行文档操作的方法
2016/03/28 Javascript
Bootstrap Table使用整理(五)之分页组合查询
2017/06/09 Javascript
Vue render渲染时间戳转时间,时间转时间戳及渲染进度条效果
2018/07/27 Javascript
10分钟彻底搞懂Http的强制缓存和协商缓存(小结)
2018/08/30 Javascript
JS闭包原理与应用经典示例
2018/12/20 Javascript
react-router-dom 嵌套路由的实现
2020/05/02 Javascript
js+canvas实现转盘效果(两个版本)
2020/09/13 Javascript
python通过字典dict判断指定键值是否存在的方法
2015/03/21 Python
Python标准模块--ContextManager上下文管理器的具体用法
2017/11/27 Python
Python 查找字符在字符串中的位置实例
2018/05/02 Python
python中报错&quot;json.decoder.JSONDecodeError: Expecting value:&quot;的解决
2019/04/29 Python
Python 继承,重写,super()调用父类方法操作示例
2019/09/29 Python
python中对_init_的理解及实例解析
2019/10/11 Python
使用python实现微信小程序自动签到功能
2020/04/27 Python
python包的导入方式总结
2021/03/02 Python
Html5游戏开发之乒乓Ping Pong游戏示例(二)
2013/01/21 HTML / CSS
canvas实现图片镜像翻转的2种方式
2020/07/22 HTML / CSS
伦敦眼门票在线预订:London Eye
2018/05/31 全球购物
党校培训思想汇报
2014/01/03 职场文书
单位婚育证明范本
2014/11/21 职场文书
先进人物事迹材料
2014/12/29 职场文书
辞职信怎么写
2015/02/27 职场文书
讲座通知范文
2015/04/23 职场文书
小学语文课《掌声》教学反思
2016/03/03 职场文书
晚会开幕词范文
2016/03/04 职场文书
来探秘“德国中小企业”的成功之道
2019/07/26 职场文书
Java基于字符界面的简易收银台
2021/06/26 Java/Android