js中实现vue2-org-tree添加自定义拖拽功能

一. 主要思路

1.1通过绑定自定义的指令,获取需要拖动的父子元素,

1.2.添加鼠标按下事件onmousedown,计算出鼠标的相对位置odiv.offsetLeft与odiv.offsetTop,

1.3.鼠标移动事件onmousemove当鼠标移动时触发,移动的时候相对位置加上偏移距离得到对应的坐标点,

1.4.odiv.style.left与 odiv.style.top动态给对应的元素添加位置样式,

1.5.onmouseup():鼠标抬起事件。当鼠标抬起触发,// 移除对鼠标移动事件的监听

 document.onmousemove = null; document.onmouseup = null;

1.6.切换页面初始化加载坐标位置保持页面垂直居中对齐// 初始化初始坐标

二. 分布实施

2.1 template结构,cursor:move->鼠标移动上变成可拖拽的样式,绑定唯一ID 获取初始化坐标原点
<template><div><div class="AllTree"><!-- cursor:move->鼠标移动上变成可拖拽的样式 --><!-- 通过绑定唯一ID 获取初始化坐标原点 --><vue2-org-treestyle="#fafafa;cursor:move"v-dragid="dragFather":data="treeData"/></div></div>
</template>
2.2 数据结构
data() {return {// 数据treeData: {id: 0,name: "",children: []},};},
2.3 activated()切换页面初始化加载坐标位置保持页面垂直居中对齐,获取id
// 切换页面初始化加载坐标位置保持页面垂直居中对齐activated() {// 初始化初始坐标const dialogHeaderEl = document.querySelector('#dragFather')dialogHeaderEl.style.left=0 + 'px';dialogHeaderEl.style.top=0 + 'px';},
2.4 自定义拖拽指令
// 开启拖拽的指令directives: {drag: {// 指令的定义bind: function (el) {var odiv = el // 获取当前元素let isMouseDown=false;//鼠标按下标记// onmousedown():鼠标按下事件。当鼠标按下时触发。odiv.onmousedown = (e) => {if(e.button===0&&!isMouseDown){// 算出鼠标相对元素的位置let offsetLeft = odiv.offsetLeftlet offsetTop = odiv.offsetTopvar disX = e.clientXvar disY = e.clientY// onmosemove():鼠标移动事件。当鼠标移动时触发document.onmousemove = (e) => {// 用鼠标的位置减去鼠标相对元素的位置,得到元素的位置// 结构沿X轴发生翻转X轴坐标变成从左到右计算的时候相反计算,var left = disX - e.clientX var top = e.clientY - disY// 移动当前元素odiv.style.left = (left + offsetLeft) + 'px'odiv.style.top = (top + offsetTop) + 'px'}isMouseDown=true}// onmouseup():鼠标抬起事件。当鼠标抬起触发//  e.button===0代表点击左键document.onmouseup = (e) => {if(e.button===0){isMouseDown=false;// 移除对鼠标移动事件的监听document.onmousemove = nulldocument.onmouseup = null}}}}}},
2.5 style样式
<style scoped>
::-webkit-scrollbar {/*隐藏滚轮*/display: none !important;}
</style>
<style lang="less" >
// 整体的结构设置
.AllTree {font-size: 12px;transform: rotateY(180deg);overflow: auto;             // 修改组件内置的样式.org-tree-node-label .org-tree-node-label-inner {cursor: pointer;padding: 0;}// 子节点.org-tree-container {position: relative;     /*定位*/display: flex;justify-content: center;align-items: center;min-height: 600px;}
}// 节点样式
.ReNode {height: 40px;min-width: 50px;transform: rotateY(180deg);background-color: rgb(238, 244, 246);display: flex;line-height: 40px;padding: 0 10px;
}</style>

三. 特别注意

由于此图结构是从右到左展示,市面上的树形结构一般是由从左到右,从上到下;要求的结构是从右到左所以在进行编写的时候利用 transform: rotateY(180deg);进行了翻转x轴发生了变化所以此处对于坐标的计算有所不同

四.代码汇总

<template><div><div class="AllTree"><!-- cursor:move->鼠标移动上变成可拖拽的样式 --><!-- 通过绑定唯一ID 获取初始化坐标原点 --><vue2-org-treestyle="#fafafa;cursor:move"v-dragid="dragFather":data="treeData"/></div></div>
</template><script>
export default {data() {return {// 数据treeData: {id: 0,name: "",children: []},};},// 切换页面初始化加载坐标位置保持页面垂直居中对齐activated() {// 初始化初始坐标const dialogHeaderEl = document.querySelector('#dragFather')dialogHeaderEl.style.left=0 + 'px';dialogHeaderEl.style.top=0 + 'px';},// 开启拖拽的指令directives: {drag: {// 指令的定义bind: function (el) {var odiv = el // 获取当前元素let isMouseDown=false;//鼠标按下标记// onmousedown():鼠标按下事件。当鼠标按下时触发。odiv.onmousedown = (e) => {if(e.button===0&&!isMouseDown){// 算出鼠标相对元素的位置let offsetLeft = odiv.offsetLeftlet offsetTop = odiv.offsetTopvar disX = e.clientXvar disY = e.clientY// onmosemove():鼠标移动事件。当鼠标移动时触发document.onmousemove = (e) => {// 用鼠标的位置减去鼠标相对元素的位置,得到元素的位置// 结构沿X轴发生翻转X轴坐标变成从左到右计算的时候相反计算,var left = disX - e.clientX var top = e.clientY - disY// 移动当前元素odiv.style.left = (left + offsetLeft) + 'px'odiv.style.top = (top + offsetTop) + 'px'}isMouseDown=true}// onmouseup():鼠标抬起事件。当鼠标抬起触发//  e.button===0代表点击左键document.onmouseup = (e) => {if(e.button===0){isMouseDown=false;// 移除对鼠标移动事件的监听document.onmousemove = nulldocument.onmouseup = null}}}}}},
};
</script><style scoped>
::-webkit-scrollbar {/*隐藏滚轮*/display: none !important;}
</style>
<style lang="less" >
// 整体的结构设置
.AllTree {font-size: 12px;transform: rotateY(180deg);overflow: auto;             // 修改组件内置的样式.org-tree-node-label .org-tree-node-label-inner {cursor: pointer;padding: 0;}// 子节点.org-tree-container {position: relative;     /*定位*/display: flex;justify-content: center;align-items: center;min-height: 600px;}
}// 节点样式
.ReNode {height: 40px;min-width: 50px;transform: rotateY(180deg);background-color: rgb(238, 244, 246);display: flex;line-height: 40px;padding: 0 10px;
}</style>

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

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

相关文章

前端面试题(计算机网络):options请求方法及使用场景

OPTIONS请求方法及使用场景 回答思路&#xff1a;什么是options请求-->options请求方法-->options使用场景什么是options请求&#xff1f;&#xff08;浅入&#xff09;扩展&#xff1a;常见的HTTP请求有什么&#xff1f;扩展&#xff1a;常见的HTTP请求的作用&#xff1…

ADS学习笔记(二)——更新中

八、中途容性负载的时延累加 1.原理简述 中途容性负载产生的第一位影响就是下冲噪声&#xff0c;第二位影响是远端信号的接收时间被延迟。电容器与传输线的组合就像一个RC滤波器&#xff0c;所以传输信号10&#xff05;&#xff5e;90&#xff05;上升边将增加&#xff0c;信…

Java-Secruity-2

可以先看这篇文章 Secruity-1&#x1f448; 1、授权 1.1 权限管理 在日常使用的系统中都会涉及到权限相关的操作&#xff0c;管理员有管理员的操作&#xff0c;用户有用户的操作&#xff0c;不同的用户可以使用不同的功能&#xff0c;这需要使用到权限管理。 所以在写接口…

iOS中宿主APP与录屏扩展进程数据传递方式

背景 在iOS生态系统中&#xff0c;应用程序的功能不再局限于单一的宿主应用&#xff0c;而是可以通过扩展进程实现更丰富的用户体验和功能。其中一种引人注目的扩展是录屏功能&#xff0c;它使用户能够捕捉设备屏幕上的活动&#xff0c;无论是游戏过程、教育演示还是其他应用场…

μC/OS-III 里面的环形表

文章目录 1、时钟节拍任务2、定时器列表 μC/OS-III 里面两个地方用到了环形表&#xff0c;时钟节拍任务&#xff0c;定时器列表&#xff0c;通过排序后&#xff0c;效率是非常高的。 以下内容整理自 嵌入式实时操作系统uC/OS-Ⅲ 1、时钟节拍任务 2023/12/21 18:04:16 (1) 该…

【数论】约数

试除法求约数 时间复杂度 O(sqrt(n))。 核心思路是求到较小的约数时&#xff0c;将其对应的较大约数也可以直接求出来&#xff0c; 例如&#xff1a;a/bc&#xff0c;b是a的余数&#xff0c;c也是a的余数 ps&#xff1a;注意bc的情况&#xff0c;要注意去重 void solve() …

JavaGUI(但期末速成版)之事件监听和处理

点击返回标题->JavaGUI期末速成版-CSDN博客 前言 依旧先声明&#xff0c;本篇记录的JavaGUI编程都是十分精简的&#xff0c;内容只取常用的、套路的、应付期末考试的。 我先放两张ppt的原内容。。。 看完&#xff08;我觉得你可能都没看完&#xff09;&#xff0c;摊牌了&a…

赴日IT培训课程 程序员新思路!

先说好&#xff0c;跟国内相比&#xff0c;日本IT并不发达。日本IT是依托着日本传统强势的制造业和政府机关发展的&#xff0c;所以开发的大多数软件也是面向这些的&#xff0c;由于日本人的严谨态度&#xff0c;各种文档的编写层出不穷&#xff0c;不像国内程序员每天没日没夜…

android 新版studio gradle 里面没有offline 勾选项

studio 右边 gradle 上面有个图标可以点击切换

【深度学习】注意力机制(七)Agent Attention

本文介绍Agent Attention注意力机制&#xff0c;Transformer中的Attention模块可以提取全局语义信息&#xff0c;但是计算量太大&#xff0c;Agent Attention是一种计算非常有效的Attention模块。 论文&#xff1a;Agent Attention: On the Integration of Softmax and Linear…

前端手动部署与自动化部署

连接服务器 先购买服务器 安装vscode插件 连接服务器 连接成功 手动部署 安装nginx 启动nginx systemctl start nginx systemctl status nginx systemctl enable nginx启动 检查状态 开机就启动nginx 开始手动部署 配置nginx 成功

【iuap学习】用友BIP|iuap平台相关资料

用友BIP|iuap平台&#xff1a;升级企业数智化底座 https://www.yonyou.com/iuap 上海第二曲线数字科技有限公司带您来了解下Paas是什么 https://baijiahao.baidu.com/s?id1775190753207512982&wfrspider&forpc 详细了解用友 iuap 的技术演进和规划 https://zhuan…

走过的2023:在挑战中领悟,在仿徨中成长

转眼间就到了2023年的最后一个月&#xff0c;回顾这短暂而又有意义的一年&#xff0c;可以用12个字总结&#xff1a;在挑战中领悟&#xff0c;在仿徨中成长。这篇文章我会从技术成长、职场生活、读书感悟和个人生活等几个方面&#xff0c;总结一下过去的这一年&#xff0c;梳理…

【LeetCode】225. 用队列实现栈(Queue接口 Deque类)

今日学习的文章链接和视频链接 leetcode题目地址&#xff1a;225. 用队列实现栈 代码随想录题解地址&#xff1a;代码随想录 题目简介 请你仅使用两个队列实现一个后入先出&#xff08;LIFO&#xff09;的栈&#xff0c;并支持普通栈的全部四种操作&#xff08;push、top、p…

【玩转TableAgent数据智能分析】——个人体验分享

文章目录 前言上手体验优势不足 再次体验第三次体验第四次体验1、找到高价房源和低价房源的特点&#xff0c;看清民宿行业的整体布局2、了解各个地域的整体价格&#xff0c;优选潜力城市3、对比各个城市的评分&#xff0c;深入了解不同城市的民宿市场特点4、对比不同床型价格&a…

Java AQS 阻塞式锁和相关同步器工具的框架

8 J.U.C Java 并发工具包 AQS 原理 AQS&#xff1a;AbstractQueuedSynchronizer&#xff08;抽象队列同步器&#xff09;&#xff0c;阻塞式锁和相关同步器工具的框架 特点&#xff1a; 用 state 属性来表示资源的状态&#xff08;分独占模式和共享模式&#xff09;&#…

TCP/IP 传输层协议

传输层定义了主机应用程序之间端到端的连通性。传输层中最为常见的两个协议分别是传输控制协议TCP&#xff08;Transmission Control Protocol&#xff09;和用户数据包协议UDP&#xff08;User Datagram Protocol&#xff09;。 TCP协议 TCP是一种面向连接的传输层协议&#…

esp32-s3解决使用蓝牙ble一键配网时,蓝牙ble内存使用的内部空间,空间不足时可采用外部PSRAM

idf.py menuconfig进入到esp32配置界面&#xff0c;配置NimBLE使用外部PSRAM内存即可

pip 离线安装:利用pypi网站进行模块 库的离线安装

离线安装是一种很好的方法&#xff0c;在网络不佳、库版本不明确、复杂库本地编译安装报错时&#xff0c;通过whl文件的下载安装&#xff0c;可以很高效的解决问题。 pypi的网站&#xff1a;https://pypi.org/ 这个网站包含各种你 pip install xxx 的库&#xff0c;离线安装可…

我做了一个在手机灵动岛锁屏看实时网速/步数/下班倒计时/跑步距离/照片/待办/倒计时/手机使用次数/帧率...的软件

我做了一个在手机灵动岛&锁屏看实时网速/步数/下班倒计时/跑步距离/照片/待办/倒计时/手机使用次数/帧率…的软件 Island Widgets 的作用&#xff1a; 提醒您 &#xff1a; 准时下班每天运动陪伴家人保持体重放下手机每日待办当前网速手机使用强度实时热搜现在天气… 初…