基于Vue.js 实现简易拖拽指令

基于 Vue.js 实现简易拖拽指令

在 Web 开发中,拖拽功能是一项常见而又实用的功能。无论是制作网页游戏、实现可拖拽的组件,还是简单的页面布局调整,都可能用到拖拽功能。在 Vue.js 中,我们可以通过自定义指令的方式来实现拖拽功能,使得代码更加模块化和可复用。本文将介绍如何基于 Vue.js 实现一个简易的拖拽指令。

1. 简介

拖拽功能的实现原理主要是通过鼠标事件(mousedown、mousemove、mouseup)来控制被拖拽元素的位置。我们需要监听鼠标按下事件,计算鼠标按下位置与被拖拽元素的偏移量,然后在鼠标移动事件中根据鼠标位置不断更新被拖拽元素的位置,最后在鼠标抬起事件中清除事件监听器。

2. 实现

我们首先定义一个 Vue 指令,命名为 drag。指令的作用是使元素可拖拽。

function updateElVisible(el, binding) {el.style.cursor = 'move';el.onmousedown = function (e) {const disx = e.pageX - el.offsetLeft;const disy = e.pageY - el.offsetTop;const maxX = document.body.clientWidth - parseInt(window.getComputedStyle(el).width);const maxY = document.body.clientHeight - parseInt(window.getComputedStyle(el).height);document.onmousemove = function (e) {let x = e.pageX - disx;let y = e.pageY - disy;x = Math.min(Math.max(x, 0), maxX);y = Math.min(Math.max(y, 0), maxY);console.log(x,'xx')el.style.left = x + 'px';el.style.top = y + 'px';};document.onmouseup = function () {document.onmousemove = document.onmouseup = null;};};
}const hasDrag = {mounted(el, binding) {updateElVisible(el, binding);},beforeUpdate(el, binding) {updateElVisible(el, binding);}
};
export default  {install(Vue) {Vue.directive('drag', hasDrag);}
};

3. 使用方法

在 Vue 组件中使用 v-drag 指令即可使元素可拖拽。

main.js
import DragDirective from './utils/drag'
.....
app.use(DragDirective)
<template><div v-drag style="width: 100px; height: 100px; background-color: #f0f0f0; position: absolute; left: 0; top: 0;">拖拽我</div>
</template>

4. 总结

通过自定义指令实现拖拽功能,可以有效地将拖拽逻辑与组件逻辑分离,使得代码更加清晰和易于维护。但是需要注意的是,拖拽功能的实现涉及到一些 DOM 操作,需要谨慎处理,以免引发意外的副作用。

希望本文对你理解如何在 Vue.js 中实现拖拽功能有所帮助!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/774810.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Maven的基础知识和应用

一、Maven基础知识 1.项目对象模型&#xff08;POM&#xff09; POM&#xff08;Project Object Model&#xff09;是Maven项目的核心配置文件&#xff0c;通常是pom.xml文件。该文件使用XML格式&#xff0c;包含了项目的所有配置信息&#xff0c;例如项目的基本信息&#xf…

chrome 浏览器报错 This page will not function without javascript enabled

This page will not function without javascript enabled. Please enable javascript on your browser. 在访问公司spark history 页面时&#xff0c;发现页面加载不全&#xff0c;并提示如上报错&#xff0c;因此按照如下步骤&#xff0c;已解决问题。 在浏览器中启用 JavaS…

OpenLayers6实战,OpenLayers绘制五角星,OpenLayers绘制特殊图形,地图上画五角星

专栏目录: OpenLayers实战进阶专栏目录 前言 本章讲解如何使用OpenLayers6在地图上绘制五角星这种特殊图形的功能。 本章上一章基础上修改而成:OpenLayers6实战,OpenLayers绘制特殊图形,OpenLayers绘制四角形(菱形),OpenLayers绘制菱形 二、依赖和使用 "ol&q…

【APP_TYC】数据采集案例天眼APP查_抓包分析_②

追寻啊 你身影千年 恳请宿命怜 无尽日夜 只为见你一面 我愿化作 窗外的桑花 朝朝暮暮 都有我牵挂 无论冬雪秋沙 海角天涯 缱绻不尽 念你啊 倘若化作 林间的桑花 借一暖风 赠你梦如画 纵使悲忧如雪 一笑融化 &#x1f3b5; Joysaaaa《朝朝如念》 抓包分析 …

.NET开源免费、功能强大的 Windows 截图录屏神器

前言 今天大姚给大家分享一款.NET开源免费&#xff08;基于GPL3.0开源协议&#xff09;、功能强大、简洁灵活的 Windows 截图、录屏、Gif动图制作神器&#xff1a;ShareX。 功能特性 ShareX 是一个开源的屏幕捕捉工具&#xff0c;具有丰富的功能特性&#xff0c;包括但不限于…

洗地机好用吗?哪款型号值得推荐?看完本文你就知道

在如今社会生活节奏不断加快的情况下&#xff0c;洗地机已经成为众多家庭的必备的清洁设备&#xff0c;面对市面上种类繁多的洗地机&#xff0c;我们常常会发出感叹“洗地机好用吗&#xff1f;洗地机哪个型好用&#xff1f;”等的疑问&#xff0c;今天&#xff0c;为了帮助大家…

vue2 export default写法,computed、methods的使用

<template><div><h2>{{nameAll}}</h2><h2>{{method}}</h2><h2>{{tt()}}</h2><h2>{{firstName}}</h2><h2>更新后赋值数据&#xff1a;{{lastName}}</h2><h2>赋值数据:{{writeValue}}</h2>…

chatgpt正面案例合集

现在可以用百度 百度安全验证 chatgpt用来搜索软件使用指令太牛了_个人渣记录仅为自己搜索用的博客-CSDN博客 chatgpt 使用案例 根据不同的目标群体变更文案和表达_个人渣记录仅为自己搜索用的博客-CSDN博客 倾听能力 和哪些基础能力相关 ,如何提高 chatgpt_个人渣记录仅为自…

el-select动态禁用

在一个el-form表单中有5个el-form-item; 每个el-form-item是一个el-select控件&#xff1b; 这5个el-select控件遵循这样的规则&#xff0c;都是使用同一个list集合&#xff0c;如果第一个el-select选择了list中的某一项&#xff0c;那么这一项就被禁用&#xff1b;其他的el-…

YOLOv9改进策略:注意力机制 | 二阶通道注意力机制(Second-order Channel Attention,SOCA),实现单图超分效果

&#x1f4a1;&#x1f4a1;&#x1f4a1;本文改进内容&#xff1a;CVPR_2019 SOCA注意力&#xff0c;一种基于二阶通道注意力机制&#xff0c;能够单幅图像超分辨率&#xff0c;从原理角度分析能够在小目标检测领域实现大幅涨点效果&#xff01;&#xff01;&#xff01; &am…

2024年3月腾讯云最新活动及优惠券整理汇总

随着云计算的普及&#xff0c;腾讯云作为国内领先的云计算服务提供商&#xff0c;为用户提供了丰富的产品和服务。为了帮助用户更好地了解和使用腾讯云&#xff0c;本文将为大家整理汇总2024年3月腾讯云的最新活动及优惠券信息。 1、腾讯云最新活动入口【点此直达】 2、腾讯云…

2024/03/27(C++·day3)

一、思维导图 二、完成下面类 代码 #include <cstring> #include <iostream>using namespace std;class myString { private:char *str; // 记录C风格的字符串int size; // 记录字符串的实际长度public:// 无参构造函数myString() : size(10){str new char[si…

双向最大匹配算法

1. 前向最大匹配算法 假定分词词典中最长词有M个汉字符&#xff0c;则被处理文档的当前字符串中前M个字作为匹配字段&#xff0c;查找词典。若字典中存在这样M个字组成的词&#xff0c;则匹配成功&#xff0c;匹配字段作为一个词切分出来&#xff1b;若匹配不成功&#xff0c;…

【Linux】进程状态(R运行状态、S睡眠状态、D磁盘休眠状态、T停止状态、X死亡状态)

目录 01.运行状态 02.睡眠状态 03.磁盘睡眠状态 04.停止状态 05.死亡状态 进程的状态会随着操作系统的调度和外部事件的发生而不断地发生转换。例如&#xff0c;一个新创建的进程经过初始化后会进入就绪态&#xff0c;等待被调度执行&#xff1b;当调度器分配处理器资源给…

windows 环境下 nginx启动,停止,重启

启动脚本 start nginx.exe2停止脚本 taskkill /f /fi "IMAGENAME eq nginx.exe"3重启脚本 echo off taskkill /f /fi "IMAGENAME eq nginx.exe" start nginx.exe #pause在nginx.exe 同级下新建.bat文件 即可

git clone 后如何 checkout 到 remote branch

what/why 通常情况使用git clone github_repository_address下载下来的仓库使用git branch查看当前所有分支时只能看到master分支&#xff0c;但是想要切换到其他分支进行工作怎么办❓ 其实使用git clone下载的repository没那么简单&#x1f625;&#xff0c;clone得到的是仓库…

一个dp题

题目链接 https://contest.ucup.ac/contest/1382/problem/7566 代码&#xff1a; #include<bits/stdc.h>using namespace std; const int N ( 1 << 24 ) 5 ; #define int long long int sum[N] , f[N] ;void solve(){int n;cin >> n;int a[28] {};for (i…

LeetCode:322. 零钱兑换(DP Java)

目录 322. 零钱兑换 题目描述&#xff1a; 原理思路与解析&#xff1a; 先物品&#xff0c;后金额的dp 先金额后物品的dp 原理思路&#xff1a; 很久很久之前写过一个C版的&#xff0c;这里再写个Java版记录一下&#xff0c;正好也是今日每日一题&#xff0c;相当于二刷再…

前端学习<二>CSS基础——04-CSS选择器:伪类

伪类&#xff08;伪类选择器&#xff09; 伪类&#xff1a;同一个标签&#xff0c;根据其不同的种状态&#xff0c;有不同的样式。这就叫做“伪类”。伪类用冒号来表示。 比如div是属于box类&#xff0c;这一点很明确&#xff0c;就是属于box类。但是a属于什么类&#xff1f;…