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 页面划词搜索JS
Sep 28 Javascript
Javascript的匿名函数小结
Dec 31 Javascript
JavaScript实现统计文本框Textarea字数增强用户体验
Dec 21 Javascript
JS复制内容到剪切板的实例代码(兼容IE与火狐)
Nov 19 Javascript
Javascript验证上传图片大小[前台处理]
Jul 18 Javascript
提交按钮的name='submit'引起的js失效问题及原因
Feb 25 Javascript
Vue.js组件通信的几种姿势
Oct 23 Javascript
js实现微信/QQ直接跳转到支付宝APP打开口令领红包功能
Jan 09 Javascript
详解Vue单元测试case写法
May 24 Javascript
JavaScript对象拷贝与赋值操作实例分析
Dec 10 Javascript
细说Vue组件的服务器端渲染的过程
May 30 Javascript
layer.open组件获取弹出层页面变量、函数的实例
Sep 25 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 生成WML页面方法详解
2009/08/09 PHP
php empty函数 使用说明
2009/08/10 PHP
PHP中Session引起的脚本阻塞问题解决办法
2014/04/08 PHP
PHP实现的只保留字符串首尾字符功能示例【隐藏部分字符串】
2019/03/11 PHP
动态样式类封装JS代码
2009/09/02 Javascript
JavaScript.Encode手动解码技巧
2010/07/14 Javascript
jQuery如何防止这种冒泡事件发生
2015/02/27 Javascript
轻松实现js图片预览功能
2016/01/18 Javascript
JavaScript函数中关于valueOf和toString的理解
2016/06/14 Javascript
AngularJS 与Bootstrap实现表格分页实例代码
2016/10/14 Javascript
基于AGS JS开发自定义贴图图层
2017/03/31 Javascript
使用Angular CLI快速创建Angular项目的一些基本概念和写法小结
2018/04/22 Javascript
深入浅出理解JavaScript高级定时器原理与用法
2018/08/02 Javascript
基于JavaScript获取url参数2种方法
2020/04/17 Javascript
JS 逻辑判断不要只知道用 if-else 和 switch条件判断(小技巧)
2020/05/27 Javascript
使用Python脚本将绝对url替换为相对url的教程
2015/04/24 Python
Python中Continue语句的用法的举例详解
2015/05/14 Python
Python中线程编程之threading模块的使用详解
2015/06/23 Python
对python中array.sum(axis=?)的用法介绍
2018/06/28 Python
Django使用中间键实现csrf认证详解
2019/07/22 Python
利用pandas将非数值数据转换成数值的方式
2019/12/18 Python
Python drop方法删除列之inplace参数实例
2020/06/27 Python
详解Pycharm安装及Django安装配置指南
2020/09/15 Python
Python 图片处理库exifread详解
2021/02/25 Python
StubHub智利:购买和出售您的门票
2016/11/23 全球购物
台湾生鲜宅配:大口市集
2017/10/14 全球购物
怎样让char类型的东西转换成int类型
2013/12/09 面试题
医院护士求职自荐信格式
2013/09/21 职场文书
实习评语大全
2014/04/26 职场文书
有关爱国演讲稿
2014/05/07 职场文书
大学生创业计划书
2014/08/14 职场文书
员工三分钟演讲稿
2014/08/19 职场文书
先进工作者申报材料
2014/12/23 职场文书
篮球赛闭幕式主持词
2015/07/03 职场文书
毕业晚宴祝酒词
2015/08/11 职场文书
MySQL获取所有分类的前N条记录
2021/05/07 MySQL