vue3自定义拖拽指令

javascript 复制代码
<template>
  <div v-move class="box">
    
  </div>
</template>

<script setup lang="ts"> 
import { Directive } from 'vue'
const vMove:Directive = (el:HTMLElement) =>{
  const mousedown = (e:MouseEvent) =>{
    // 鼠标按下
    const startX = e.clientX - el.offsetLeft;
    const startY = e.clientY  - el.offsetHeight;
    const move = (e:MouseEvent)=> {
      console.log('坐标',e.clientX, e.clientY);
      // 鼠标移动
      const moveX = e.clientX;
      const moveY = e.clientY;
      const disX = moveX - startX;
      const disY = moveY - startY;
      el.style.top = disY + 'px'
      el.style.left = disX + 'px'
    }
    const up = () => {
      // 鼠标抬起
      document.removeEventListener('mousemove',move)
      document.removeEventListener('mouseup',up)
    } 
    document.addEventListener('mousemove',move)
    document.addEventListener('mouseup',up)
  }
  el.addEventListener('mousedown',mousedown)
} 
</script>

<style scoped>
.box {
  width: 400px;
  height: 400px;
  background: pink;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
</style>


相关推荐
2301_8184190129 分钟前
C++中的解释器模式变体
开发语言·c++·算法
跟着珅聪学java34 分钟前
js编写中文转unicode 教程
前端·javascript·数据库
英俊潇洒美少年1 小时前
Vue3 深入响应式系统
前端·javascript·vue.js
摇滚侠1 小时前
Java 项目《谷粒商城-1》架构师级Java 项目实战,对标阿里 P6-P7,全网最强,实操版本
java·开发语言
颜酱1 小时前
回溯算法实战练习(3)
javascript·后端·算法
biter down1 小时前
C++11 统一列表初始化+std::initializer_list
开发语言·c++
我命由我123452 小时前
React Router 6 - 概述、基础路由、重定向、NavLink、路由表
前端·javascript·react.js·前端框架·ecmascript·html5·js
telllong2 小时前
BeeWare:Python原生移动应用开发
开发语言·python
yaaakaaang3 小时前
(四)前端,如此简单!---Promise
前端·javascript
海海不瞌睡(捏捏王子)3 小时前
C#知识点概要
java·开发语言·1024程序员节