原生JS实现拖拽功能


Posted in Javascript onDecember 16, 2020

本文实例为大家分享了JS实现拖拽功能的具体代码,供大家参考,具体内容如下

拖拽的原理:三个事件 onmousedownonmousemoveonmousemove

1、鼠标按下,触发onmousedown,获取鼠标坐标x,y,获取元素坐标x,y

通过event.clientX、event.clientY获取鼠标位置的坐标

let x = e.clientX - box.offsetLeft; //鼠标点击坐标距离盒子左边缘的距离
let y = e.clientY - box.offsetTop; //鼠标点击坐标距离盒子上边缘的距离

2、设置元素left、top值,(元素要设置position:absolute)

box.style.left = ev.clientX - x + 'px';
box.style.top = ev.clientY - y + 'px';

3、放开鼠标取消dom事件

下面是详细代码:我只开了横向移动

<!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>Document</title>
 <style>
 #box {
 width: 100px;
 height: 100px;
 background: red;
 position: absolute
 }
 
 </style>
</head>
 
<body style="position: relative;overflow: hidden;">
 <div id="box">
 
 </div>
 
 <script>
 window.onload = function () {
 let box = document.getElementById('box')
 box.onmousedown = function (ev) {
 let e = ev || event;
 let x = e.clientX - box.offsetLeft; //鼠标点击坐标距离盒子左边缘的距离
 let y = e.clientY - box.offsetTop; //鼠标点击坐标距离盒子上边缘的距离
 document.onmousemove = function (ev) {
  let e = ev || event;
  box.style.left = ev.clientX - x + 'px';
  box.style.top = ev.clientY - y + 'px';
  
  let bodyScreenX = ev.screenX
  let bodyClientWidth = document.body.clientWidth
  
  document.onmouseup = function (ev) {
  if (ev.clientX - x < 0) {
  box.style.left = 0
  } else if (bodyScreenX > bodyClientWidth) {
  box.style.right = 0
  box.style.left = bodyClientWidth - 100 + 'px'
  }
  document.onmousemove = null;
  document.onmouseup = null;
  }
 }
 }
 }
 
 </script>
</body>
 
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
HTML页面如何象ASP一样接受参数
Feb 07 Javascript
详解JS 比较两个Json对象的值是否相等的实例
Nov 20 Javascript
JS定义网页表单提交(submit)的方法
Mar 20 Javascript
js判断图片加载完成后获取图片实际宽高的方法
Feb 25 Javascript
jQuery图片前后对比插件beforeAfter用法示例【附demo源码下载】
Sep 20 Javascript
微信小程序 开发工具快捷键整理
Oct 31 Javascript
JavaScript之class继承_动力节点Java学院整理
Jul 03 Javascript
微信小程序实现给嵌套template模板传递数据的方式总结
Dec 18 Javascript
layer.confirm取消按钮绑定事件的方法
Aug 17 Javascript
JS如何获取地址栏的参数实例讲解
Oct 06 Javascript
js实现旋转的星空效果
Nov 01 Javascript
jQuery实现简单评论区功能
Oct 26 jQuery
vue图片裁剪插件vue-cropper使用方法详解
Dec 16 #Vue.js
vue实现图片裁剪后上传
Dec 16 #Vue.js
Vue-router中hash模式与history模式的区别详解
Dec 15 #Vue.js
JS创建自定义对象的六种方法总结
Dec 15 #Javascript
npm全局环境变量配置详解
Dec 15 #Javascript
vue项目中企业微信使用js-sdk时config和agentConfig配置方式详解
Dec 15 #Vue.js
angular *Ngif else用法详解
Dec 15 #Javascript
You might like
The specified CGI application misbehaved by not returning a complete set of HTTP headers
2011/03/31 PHP
PHP里的中文变量说明
2011/07/23 PHP
探讨如何把session存入数据库
2013/06/07 PHP
解析PHP强制转换类型及远程管理插件的安全隐患
2014/06/30 PHP
PHP基于pdo的数据库操作类【可支持mysql、sqlserver及oracle】
2018/05/21 PHP
PHP实现的服务器一致性hash分布算法示例
2018/08/09 PHP
在UpdatePanel内jquery easyui效果失效的解决方法
2010/04/11 Javascript
jQuery常见开发技巧详细整理
2013/01/02 Javascript
提升PHP安全:8个必须修改的PHP默认配置
2014/11/17 Javascript
JavaScript操作Cookie方法实例分析
2015/05/27 Javascript
PhantomJS快速入门教程(服务器端的 JavaScript API 的 WebKit)
2015/08/06 Javascript
HTML页面,测试JS对C函数的调用简单实例
2016/08/09 Javascript
p5.js入门教程之小球动画示例代码
2018/03/15 Javascript
vue打包之后生成一个配置文件修改接口的方法
2018/12/09 Javascript
JS/HTML5游戏常用算法之路径搜索算法 A*寻路算法完整实例
2018/12/14 Javascript
webpack4 SplitChunks实现代码分隔详解
2019/05/23 Javascript
VUE安装使用教程详解
2019/06/03 Javascript
VUE前后端学习tab写法实例
2019/08/06 Javascript
JS函数基本定义与用法示例
2020/01/15 Javascript
Selenium执行Javascript脚本参数及返回值过程详解
2020/04/01 Javascript
VUE中V-IF条件判断改变元素的样式操作
2020/08/09 Javascript
Python将多个list合并为1个list的方法
2018/06/27 Python
新锐科技Java程序员面试题
2016/07/25 面试题
教学实习自我评价
2014/01/28 职场文书
幼儿园教师个人反思
2014/01/30 职场文书
班主任个人工作反思
2014/04/28 职场文书
师范生自荐信模板
2014/05/28 职场文书
代领毕业证委托书
2014/08/02 职场文书
群众路线表态发言材料
2014/10/17 职场文书
简易离婚协议书范本
2014/10/24 职场文书
联谊会开场白
2015/06/01 职场文书
在职证明格式样本
2015/06/15 职场文书
新学期感想
2015/08/10 职场文书
污染环境建议书
2015/09/14 职场文书
Python 数据可视化之Matplotlib详解
2021/11/02 Python
Nginx的gzip相关介绍
2022/05/11 Servers