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 相关文章推荐
js escape,unescape解决中文乱码问题的方法
May 26 Javascript
IE8下Jquery获取select选中的值post到后台报错问题
Jul 02 Javascript
jquery+json实现数据二级联动的方法
Nov 28 Javascript
jQuery实现监控页面所有ajax请求的方法
Dec 10 Javascript
JavaScript代码性能优化总结篇
May 15 Javascript
JavaScript操作选择对象的简单实例
May 16 Javascript
jQuery Ajax全解析
Feb 13 Javascript
vue动态组件实现选项卡切换效果
Mar 08 Javascript
vue的无缝滚动组件vue-seamless-scroll实例
Dec 18 Javascript
微信小程序chooseImage的用法(从本地相册选择图片或使用相机拍照)
Aug 22 Javascript
微信小程序完美解决scroll-view高度自适应问题的方法
Aug 08 Javascript
vue中选中多个选项并且改变选中的样式的实例代码
Sep 16 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+JS实现搜索自动提示(实例)
2013/06/09 PHP
关于url地址传参数时字符串有回车造成页面脚本赋值失败的解决方法
2013/06/28 PHP
PHP curl 获取响应的状态码的方法
2014/01/13 PHP
使用php方法curl抓取AJAX异步内容思路分析及代码分享
2014/08/25 PHP
php实现在新浪云中使用imagick生成缩略图并上传的方法
2016/09/26 PHP
在php的yii2框架中整合hbase库的方法
2018/09/20 PHP
CSS中简写属性要注意TRouBLe的顺序问题(避免踩坑)
2021/03/09 HTML / CSS
qTip 基于JQuery的Tooltip插件[兼容性好]
2010/09/01 Javascript
弹出最简单的模式化遮罩层的js代码
2013/12/04 Javascript
JS清空多文本框、文本域示例代码
2014/02/24 Javascript
js简单实现表单中点击按钮动态增加输入框数量的方法
2015/08/18 Javascript
JS命令模式例子之菜单程序
2016/10/10 Javascript
easyui messager alert 三秒后自动关闭提示的实例
2016/11/07 Javascript
js获取一组日期中最近连续的天数
2017/05/25 Javascript
javascript 中事件冒泡和事件捕获机制的详解
2017/09/01 Javascript
Vue组件开发之LeanCloud带图形校验码的短信发送功能
2017/11/07 Javascript
快速解决brew安装特定版本flow的问题
2018/05/17 Javascript
微信小程序日期选择器实例代码
2018/07/18 Javascript
vue、react等单页面项目部署到服务器的方法及vue和react的区别
2018/09/29 Javascript
vue.js多页面开发环境搭建过程
2019/04/24 Javascript
jQuery实现二级导航菜单的示例
2020/09/30 jQuery
跟老齐学Python之不要红头文件(2)
2014/09/28 Python
python动态参数用法实例分析
2015/05/25 Python
获取python文件扩展名和文件名方法
2018/02/02 Python
Python global全局变量函数详解
2018/09/18 Python
Python操作MySQL数据库的两种方式实例分析【pymysql和pandas】
2019/03/18 Python
Python3 中sorted() 函数的用法
2020/03/24 Python
matplotlib部件之矩形选区(RectangleSelector)的实现
2021/02/01 Python
Python 求向量的余弦值操作
2021/03/04 Python
.net C#面试题
2012/08/28 面试题
夜大毕业自我鉴定
2013/10/11 职场文书
违纪开除通知书
2015/04/25 职场文书
2015年教师学期工作总结
2015/04/30 职场文书
投资入股协议书
2016/03/22 职场文书
工作汇报材料难写?方法都在这里了!
2019/07/01 职场文书
tomcat正常启动但网页却无法访问的几种解决方法
2022/05/06 Servers