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 相关文章推荐
JQuery中html()方法使用不当带来的陷阱
Apr 07 Javascript
vue.js+Echarts开发图表放大缩小功能实例
Jun 09 Javascript
浅谈react+es6+webpack的基础配置
Aug 09 Javascript
jQuery模拟爆炸倒计时功能实例代码
Aug 21 jQuery
vue 过滤器filter实例详解
Mar 14 Javascript
r.js来合并压缩css文件的示例
Apr 26 Javascript
详解在vue-test-utils中mock全局对象
Nov 07 Javascript
layui将table转化表单显示的方法(即table.render转为表单展示)
Sep 24 Javascript
解决vue-router 二级导航默认选中某一选项的问题
Nov 01 Javascript
Vue使用JSEncrypt实现rsa加密及挂载方法
Feb 07 Javascript
vue.js中使用微信扫一扫解决invalid signature问题(完美解决)
Apr 11 Javascript
JavaScript面试中常考的字符串操作方法大全(包含ES6)
May 10 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中使用redis队列操作实例代码
2013/02/07 PHP
php设计模式之策略模式实例分析【星际争霸游戏案例】
2020/03/26 PHP
PHP连接MySQL数据库三种实现方法
2020/12/10 PHP
javascript的trim,ltrim,rtrim自定义函数
2008/09/21 Javascript
js中字符替换函数String.replace()使用技巧
2011/08/14 Javascript
jQuery on方法传递参数示例
2014/12/09 Javascript
jQuery中dequeue()方法用法实例
2014/12/29 Javascript
JS组件Bootstrap dropdown组件扩展hover事件
2016/04/17 Javascript
深入理解jQuery layui分页控件的使用
2016/08/17 Javascript
Angular ng-class详解及实例代码
2016/09/19 Javascript
微信小程序  自定义创建详细介绍
2016/10/27 Javascript
AngularJs中Bootstrap3 datetimepicker使用实例
2016/12/13 Javascript
使用BootStrap实现标签切换原理解析
2017/03/14 Javascript
JavaScript的继承实现小结
2017/05/07 Javascript
JS手机端touch事件计算滑动距离的方法示例
2017/10/26 Javascript
[02:36]DOTA2混沌骑士 英雄基础教程
2013/11/26 DOTA
R vs. Python 数据分析中谁与争锋?
2017/10/18 Python
python机器学习案例教程——K最近邻算法的实现
2017/12/28 Python
详解Django的model查询操作与查询性能优化
2018/10/16 Python
Tensorflow模型实现预测或识别单张图片
2019/07/19 Python
django实现将后台model对象转换成json对象并传递给前端jquery
2020/03/16 Python
python plt可视化——打印特殊符号和制作图例代码
2020/04/17 Python
Python基于Twilio及腾讯云实现国际国内短信接口
2020/06/18 Python
美国木工工具和用品商店:Woodcraft
2019/10/30 全球购物
介绍一下sql server的安全性
2014/08/10 面试题
索引覆盖(Index Covering)查询含义
2012/02/18 面试题
高中的职业生涯规划书
2013/12/28 职场文书
2014幼儿园教师师德师风演讲稿
2014/09/10 职场文书
党员干部反四风民主生活会对照检查材料思想汇报
2014/10/12 职场文书
护士2014年终工作总结
2014/11/11 职场文书
千手观音观后感
2015/06/03 职场文书
六一儿童节新闻稿
2015/07/17 职场文书
六五普法先进个人主要事迹材料
2015/11/03 职场文书
python playwright 自动等待和断言详解
2021/11/27 Python
游戏《铁拳》动画化!2022年年内播出
2022/03/21 日漫
SpringBoot2零基础到精通之数据库专项精讲
2022/03/22 Java/Android