vue,div实现拖动,并给新位置

ops/2024/11/15 0:27:33/

鼠标方上去随意拖动到其它位置
在这里插入图片描述


<template><div style="margin: 50px;"><div class="dade draggable-div"  @mousedown="startDrag($event)" @mouseup="stopDrag" @mousemove="drag($event)"style="width: 200px;height: 200px;border: 1px solid #e7e7e7;cursor: all-scroll;"></div></div>
</template><script>export default {data() {return {isDragging: false,startX: 0,startY: 0,currentX: 0,currentY: 0};},watch: {},//界面没出来前加载created() {this.list = menu_tree;},mounted() {},computed: {},methods: {//鼠标按下startDrag(event) {this.isDragging = true;this.startX = event.clientX;this.startY = event.clientY;this.currentX = parseInt(event.target.offsetLeft);this.currentY = parseInt(event.target.offsetTop);// event.target.style.cursor = 'grabbing';document.addEventListener('mousemove', this.drag);document.addEventListener('mouseup', this.stopDrag);},drag(event) {if (this.isDragging) {const diffX = event.clientX - this.startX;const diffY = event.clientY - this.startY;event.target.style.left = this.currentX + diffX + 'px';event.target.style.top = this.currentY + diffY + 'px';}},stopDrag() {this.isDragging = false;// event.target.style.cursor = 'grab';document.removeEventListener('mousemove', this.drag);document.removeEventListener('mouseup', this.stopDrag);}}
};
</script><style scoped>.dade{-webkit-box-shadow: 0 2px 0px 0 rgba(0,0,0,.1);box-shadow: 0 2px 12px 0 rgba(0,0,0,.1);}.draggable-div {position: absolute;}
</style>

http://www.ppmy.cn/ops/98456.html

相关文章

除了Synchronized和ReentrantLock外,有哪些别的同步机制

除了synchronized和ReentrantLock外&#xff0c;有哪些别的同步机制 答案&#xff1a; Java提供了多种同步机制和锁用来满足不同的并发需求。除synchronized和ReentrantLock之外&#xff0c;还有以下几种&#xff1a; 1. CountDownLatch&#xff08;倒计时器&#xff09;&am…

iOS 通知

iOS 通知分为本地推送和远程推送两类 一. 本地推送使用流程 1. 注册通知 //请求通知权限 UNUserNotificationCenter *center [UNUserNotificationCenter currentNotificationCenter];[center requestAuthorizationWithOptions:(UNAuthorizationOptionBadge | UNAuthorizati…

LangGPT结构化提示词编写实践

配置环境 创建文件夹&#xff0c;安装软件 创建窗口&#xff0c;激活环境 部署成功 测试部署成功 进入页面

ClickHouse集群的安装

目录 1.clickhouse中文文档地址 2.centos安装部署 2.1采用tgz的方式安装 2.2修改配置文件 2.3修改数据目录 2.4创建角色和目录 3 集群安装 3.1配置文件修改 3.2启动zookeeper 3.3启动clickhouse-server 3.4任意节点连接clickhouse 3.5查看集群 3.6建库 3.7查看数…

LeetCode.55.跳跃游戏(贪心算法思路)

题目描述&#xff1a; 给你一个非负整数数组 nums &#xff0c;你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标&#xff0c;如果可以&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 输…

C# 数组(Array)

C# 数组&#xff08;Array&#xff09; C# 中的数组是一种数据结构&#xff0c;用于存储一系列具有相同数据类型的元素。数组在内存中连续存储元素&#xff0c;这使得数组在访问元素时非常高效。在 C# 中&#xff0c;数组可以是单维的&#xff0c;也可以是多维的。此外&#x…

Vulkan 学习(4)---- Vulkan 逻辑设备

目录 Vulkan Logical Device OverView逻辑设备创建VkDeviceQueueCreateInfoDeviceExtension获取DeviceQueue参考代码 Vulkan Logical Device OverView 在 Vulkan 中&#xff0c;逻辑设备(Logical Device)是与物理设备(Physical Device)交互的接口,它抽象了对特定GPU(物理设备)…

笔记-系统规划与管理师-案例题-2023年-服务持续改进

【说明】 X公司主营运维服务业务&#xff0c;上一年度客户满意度明显下降&#xff0c;为寻找公司服务实施过程中存在的问题和缺陷&#xff0c;并提供服务改进活动有效实施的目标和方向&#xff0c;保证组织的服务质量稳定可控&#xff0c;公司决定让小王负责运维服务质量管理工…