原生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 相关文章推荐
Prototype Hash对象 学习
Jul 19 Javascript
JavaScript写的一个自定义弹出式对话框代码
Jan 17 Javascript
初学js插入节点appendChild insertBefore使用方法
Jul 04 Javascript
JavaScript中的apply()方法和call()方法使用介绍
Jul 25 Javascript
javascript继承之为什么要继承
Nov 10 Javascript
jquery+html5烂漫爱心表白动画代码分享
Aug 24 Javascript
JS实现的幻灯片切换显示效果
Sep 07 Javascript
js微信应用场景之微信音乐相册案例分享
Aug 11 Javascript
Javascript中将变量转换为字符串的三种方法
Sep 19 Javascript
vue2.0 中使用transition实现动画效果使用心得
Aug 13 Javascript
layer.msg()去掉默认时间,实现手动关闭的方法
Sep 12 Javascript
微信小程序实现列表的横向滑动方式
Jul 15 Javascript
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
图形数字验证代码
2006/10/09 PHP
隐藏X-Space个人空间下方版权方法隐藏X-Space个人空间标题隐藏X-Space个人空间管理版权方法
2007/02/22 PHP
使用PHP提取视频网站页面中的FLASH地址的代码
2010/04/17 PHP
php 无限级数据JSON格式及JS解析
2010/07/17 PHP
PHP函数之error_reporting(E_ALL ^ E_NOTICE)详细说明
2011/07/01 PHP
php设计模式小结
2013/02/15 PHP
PHP实现cookie跨域session共享的方法分析
2019/08/23 PHP
prototype 1.5相关知识及他人笔记
2006/12/16 Javascript
js multiple全选与取消全选实现代码
2012/12/04 Javascript
JS+CSS实现表格高亮的方法
2015/08/05 Javascript
mpvue+vuex搭建小程序详细教程(完整步骤)
2018/09/30 Javascript
uni-app微信小程序登录并使用vuex存储登录状态的思路详解
2019/11/04 Javascript
vuex入门最详细整理
2020/03/04 Javascript
微信小程序入门之绘制时钟
2020/10/22 Javascript
[04:02]2014DOTA2国际邀请赛 BBC每日综述中国战队将再度登顶
2014/07/21 DOTA
跟老齐学Python之有容乃大的list(1)
2014/09/14 Python
Ubuntu下安装PyV8
2016/03/13 Python
python实现多层感知器
2019/01/18 Python
python下的opencv画矩形和文字注释的实现方法
2019/07/09 Python
Pytorch之view及view_as使用详解
2019/12/31 Python
python使用列表的最佳方案
2020/08/12 Python
Python实现我的世界小游戏源代码
2021/03/02 Python
使用HTML5在网页中嵌入音频和视频播放的基本方法
2016/02/22 HTML / CSS
SKECHERS官方旗舰店:美国舒适运动休闲品牌
2017/12/22 全球购物
现代生活方式的家具和装饰:Dot & Bo
2018/12/26 全球购物
阿玛尼美妆俄罗斯官网:Giorgio Armani Beauty RU
2020/07/19 全球购物
2014年迎新年活动方案
2014/02/19 职场文书
党员群众路线对照检查材料思想汇报
2014/09/17 职场文书
2014年护士工作总结范文
2014/11/11 职场文书
英语邀请函范文
2015/02/02 职场文书
大学毕业生自我评价
2015/03/02 职场文书
个人德育工作总结
2015/03/05 职场文书
2016党校培训心得体会
2016/01/07 职场文书
MySQL如何解决幻读问题
2021/08/07 MySQL
关于maven依赖 ${xxx.version}报错问题
2022/01/18 Java/Android
React如何使用axios请求数据并把数据渲染到组件
2022/08/05 Javascript