原生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 相关文章推荐
juqery 学习之三 选择器 子元素与表单
Nov 25 Javascript
更优雅的事件触发兼容
Oct 24 Javascript
jQuery源码分析-04 选择器-Sizzle-工作原理分析
Nov 14 Javascript
jQuery中$.fn的用法示例介绍
Nov 05 Javascript
运用JQuery的toggle实现网页加载完成自动弹窗
Mar 18 Javascript
深入理解JavaScript系列(25):设计模式之单例模式详解
Mar 03 Javascript
全面理解JavaScript中的继承(必看)
Jun 16 Javascript
JavaScript中使用webuploader实现上传视频功能(demo)
Apr 10 Javascript
JS如何获取地址栏的参数实例讲解
Oct 06 Javascript
微信小程序实现的日期午别医生排班表功能示例
Jan 09 Javascript
JavaScript享元模式原理与用法实例详解
Mar 09 Javascript
详解JavaScript 中的批处理和缓存
Nov 19 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
《PHP边学边教》(01.开篇――准备工作)
2006/12/13 PHP
PHP版自动生成文章摘要
2008/07/23 PHP
PHP递归删除目录几个代码实例
2014/04/21 PHP
php缩放gif和png图透明背景变成黑色的解决方法
2014/10/14 PHP
php简单日历函数
2015/10/28 PHP
Yii2中如何使用modal弹窗(基本使用)
2016/05/30 PHP
ThinkPHP 整合Bootstrap Ajax分页样式
2016/12/23 PHP
js textarea自动增高并隐藏滚动条
2009/12/16 Javascript
json的定义、标准格式及json字符串检验
2014/05/11 Javascript
javascript函数中参数传递问题示例探讨
2014/07/31 Javascript
jquery实现html页面 div 假分页有原理有代码
2014/09/06 Javascript
jquery 实现返回顶部功能
2014/11/17 Javascript
深入理解JavaScript系列(36):设计模式之中介者模式详解
2015/03/04 Javascript
javascript的BOM汇总
2015/07/16 Javascript
JavaScript实现的伸展收缩型菜单代码
2015/10/14 Javascript
JS实现超简单的鼠标拖动效果
2015/11/02 Javascript
详解javascript高级定时器
2015/12/31 Javascript
Angular.js与Bootstrap相结合实现手风琴菜单代码
2016/04/13 Javascript
详解nodejs 文本操作模块-fs模块(一)
2016/12/22 NodeJs
js面向对象之实现淘宝放大镜
2020/01/15 Javascript
如何用JS模拟实现数组的map方法
2020/07/30 Javascript
echarts实现晶体球面投影的实例教程
2020/10/10 Javascript
vuejs实现下拉框菜单选择
2020/10/23 Javascript
[46:53]Secret vs Liquid 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
python通过Windows下远程控制Linux系统
2018/06/20 Python
使用Python生成200个激活码的实现方法
2019/11/22 Python
python super用法及原理详解
2020/01/20 Python
python GUI库图形界面开发之PyQt5窗口背景与不规则窗口实例
2020/02/25 Python
Python搭建Keras CNN模型破解网站验证码的实现
2020/04/07 Python
学python需要去培训机构吗
2020/07/01 Python
StubHub德国:购买和出售门票
2017/09/06 全球购物
某公司面试题
2012/03/05 面试题
金融事务专业求职信
2014/04/25 职场文书
化工见习报告范文
2014/10/31 职场文书
idea搭建可运行Servlet的Web项目
2021/06/26 Java/Android
MySQL query_cache_type 参数与使用详解
2021/07/01 MySQL