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 相关文章推荐
javascript实现的动态文字变换
Jul 28 Javascript
用最通俗易懂的代码帮助新手理解javascript闭包 推荐
Mar 01 Javascript
Node.js中创建和管理外部进程详解
Aug 16 Javascript
根据配置文件加载js依赖模块
Dec 29 Javascript
js基本算法:冒泡排序,二分查找的简单实例
Oct 08 Javascript
js中获取 table节点各tr及td的内容简单实例
Oct 14 Javascript
关于Vue单页面骨架屏实践记录
Dec 13 Javascript
js input输入百分号保存数据库失败的解决方法
May 26 Javascript
Vue-Router基础学习笔记(小结)
Oct 15 Javascript
vue登录注册实例详解
Sep 14 Javascript
jQuery实现的分页插件完整示例
May 26 jQuery
Ajax是什么?Ajax高级用法之Axios技术
Apr 21 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注释实例技巧
2008/10/03 PHP
PHP 裁剪图片成固定大小代码方法
2009/09/09 PHP
PHP使用PDO连接ACCESS数据库
2015/03/05 PHP
教你php如何实现验证码
2016/01/20 PHP
php处理抢购类功能的高并发请求
2018/02/08 PHP
PHP读取文件,解决中文乱码UTF-8的方法分析
2020/01/22 PHP
用javascript实现的激活输入框后隐藏初始内容
2007/06/29 Javascript
Javascript中定义方法的另类写法(批量定义js对象的方法)
2011/02/25 Javascript
jQuery实现动画效果的实例代码
2013/05/07 Javascript
JS是按值传递还是按引用传递
2015/01/30 Javascript
js设置document.domain实现跨域的注意点分析
2015/05/21 Javascript
JavaScript实现给定时间相加天数的方法
2016/01/25 Javascript
jQuery模拟360浏览器切屏效果幻灯片(附demo源码下载)
2016/01/29 Javascript
关于JS Lodop打印插件打印Bootstrap样式错乱问题的解决方案
2016/12/23 Javascript
Nodejs回调加超时限制两种实现方法
2017/06/09 NodeJs
JavaScript数组排序reverse()和sort()方法详解
2017/12/24 Javascript
Element-ui table中过滤条件变更表格内容的方法
2018/03/02 Javascript
Django返回json数据用法示例
2016/09/18 Python
python正则表达式之对号入座篇
2018/07/24 Python
Django进阶之CSRF的解决
2018/08/01 Python
使用pyinstaller打包PyQt4程序遇到的问题及解决方法
2019/06/24 Python
运行tensorflow python程序,限制对GPU和CPU的占用操作
2020/02/06 Python
python3获取控制台输入的数据的具体实例
2020/08/16 Python
Miller Harris官网:英国小众香水品牌
2020/09/24 全球购物
数据库测试通常都包括哪些方面
2015/11/30 面试题
推荐信怎么写
2014/05/09 职场文书
服装设计师求职信
2014/06/04 职场文书
中考标语大全
2014/06/05 职场文书
写字楼租赁意向书
2014/07/30 职场文书
党的群众路线教育实践活动对照检查材料范文
2014/09/24 职场文书
党员教师四风问题对照检查材料
2014/09/26 职场文书
导游词之太行山青龙峡
2020/01/14 职场文书
mysql对于模糊查询like的一些汇总
2021/05/09 MySQL
Python数据分析之绘图和可视化详解
2021/06/02 Python
详解JS数组方法
2021/11/20 Javascript
一级电子管军用接收机测评
2022/04/05 无线电