鼠标拖拽盒子移动

目录

需求

浮动的盒子添加鼠标拖拽功能

思路

  1. 给需要拖动的盒子添加鼠标按下事件
  2. 鼠标按下后获取鼠标点击位置与盒子边缘的距离
  3. 给 document 添加鼠标移动事件
  4. 鼠标移动过程中,将盒子的位置进行重新定位
  5. 侦听 document 鼠标弹起,移除鼠标移动事件

代码

html 复制代码
<!-- 鼠标拖拽盒子 -->
<template>
  <div>
    <!-- 【1】给需要拖动的盒子添加鼠标按下事件 -->
    <div ref="btns" class="btns" @mousedown="mousedownHandler">试试拖动我</div>
  </div>
</template>

<script>
export default {
  name: 'Drag',
  components: {},

  data() {
    return {
      mouseToBoxRangeX: 0, // 鼠标点击位置与盒子边缘的距离
      mouseToBoxRangeY: 0 // 鼠标点击位置与盒子边缘的距离
    }
  },

  computed: {},

  watch: {},

  mounted() {
    // 【5】侦听 document 鼠标弹起,移除鼠标移动事件
    document.addEventListener('mouseup', () => {
      document.removeEventListener('mousemove', this.mousemoveHandler)
    })
  },

  methods: {
    mousedownHandler($event) {
      // 【2】鼠标按下后获取鼠标点击位置与盒子边缘的距离
      //  鼠标点击位置与盒子边缘的距离 = 鼠标点击位置 - 盒子当前位置
      this.mouseToBoxRangeX = $event.pageX - this.$refs.btns.offsetLeft
      this.mouseToBoxRangeY = $event.pageY - this.$refs.btns.offsetTop
      // 【3】给 document 添加鼠标移动事件
      document.addEventListener('mousemove', this.mousemoveHandler)
    },
    mousemoveHandler($event) {
      // 【4】鼠标移动过程中,将盒子的位置进行重新定位
      // 盒子当前位置 = 鼠标点击位置 - 鼠标点击位置与盒子边缘的距离 - 盒子自身设定的边距(此处没有)
      // 【注意】设置盒子最新位置时需加上单位 'px'
      this.$refs.btns.style.left = $event.pageX - this.mouseToBoxRangeX + 'px'
      this.$refs.btns.style.top = $event.pageY - this.mouseToBoxRangeY + 'px'
    }
  }
}
</script>

<style lang='scss' scoped>
.btns {
  width: 70px;
  height: 147px;
  position: absolute;
  bottom: 10px;
  right: 10px;
  z-index: 2000;
  cursor: move;
  background-color: red;
}
</style>

页面展示

【补充】纯js实现

html 复制代码
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta http-equiv="X-UA-Compatible" content="IE=edge" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<title>Document</title>
		<style>
			* {
				margin: 0;
				padding: 0;
			}

			.box {
				position: relative;
				width: 100px;
				height: 100px;
				background-color: tomato;
				margin: 100px;
			}
		</style>
	</head>

	<body>
		<div class="box"></div>
		<script>
			/* 
		        效果:鼠标拖着盒子移动
		        拖着:
		            鼠标左键按着不松手(mousedown),然后鼠标移动(mousemove)
		        注意:鼠标左键按下,才注册上了鼠标移动事件
	        */
			var box = document.querySelector('.box')

			// 添加鼠标点击事件
			box.addEventListener('mousedown', function (e) {
				console.log('this----', this)
				console.log('this.offsetLeft----', this.offsetLeft)
				console.log('this.offsetTop----', this.offsetTop)
				// 【1】获取鼠标在盒子里的位置
				// 鼠标的坐标 - 盒子的坐标
				var x = e.pageX - this.offsetLeft
				var y = e.pageY - this.offsetTop
				console.log(x, y)

				// 注册鼠标移动事件(给整个document添加 事件)
				document.addEventListener('mousemove', move)

				function move(e) {
					// 【2】设置盒子的位置(注意 给盒子添加定位)
					// 鼠标的坐标 - 鼠标在盒子里的坐标
					// 【2.1】盒子没有外边距
					// box.style.left = (e.pageX - x) + 'px';
					// box.style.top = (e.pageY - y) + 'px';

					// 【2.2】盒子有外边距
					box.style.left = e.pageX - x - 100 + 'px'
					box.style.top = e.pageY - y - 100 + 'px'
				}
				// 【3】鼠标弹起,删除移动事件
				document.addEventListener('mouseup', function () {
					// 删除鼠标移动事件
					document.removeEventListener('mousemove', move)
				})
			})
		</script>
	</body>
</html>
相关推荐
进击的_鹏16 分钟前
【C++】list 链表的使用+模拟实现
开发语言·c++·链表
m0_7383556924 分钟前
java泛型
java·开发语言
大模型铲屎官40 分钟前
哈希表入门到精通:从原理到 Python 实现全解析
开发语言·数据结构·python·算法·哈希算法·哈希表
十步杀一人_千里不留行1 小时前
React Native 下拉选择组件首次点击失效问题的深入分析与解决
javascript·react native·react.js
L_09071 小时前
【C】队列与栈的相互转换
c语言·开发语言·数据结构
qq4054251971 小时前
基于python的旅客游记和轨迹分析可视化系统设计(新)
开发语言·python
C#Thread1 小时前
C#上位机--进程和线程的区别
java·开发语言
DKPT1 小时前
计算机网络之路由协议(自治系统)
开发语言·笔记·学习·计算机网络·算法
水月梦镜花2 小时前
数据结构:基数排序(c++实现)
开发语言·数据结构·c++
m0_594526302 小时前
基于 PyQt5 实现分组列表滚动吸顶效果
开发语言·python·qt