怎样用vue实现拖拽树状图的功能?
Admin 2021-08-31 群英技术资讯 1135 次浏览
这篇文章主要介绍怎样用vue实现拖拽树状图,下文有实例有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章能有所收获,接下来小编带着大家一起了解看看。
结构通过Vue的递归组件实现
布局使用flex,结构线由CSS伪类实现
需要注意的是居中布局,当X轴元素过多导致子元素宽度超出视图,元素居中后虽然有滚动条,但只能到达右边的内容,左边的内容会无法访问,可以把父元素设置为inline-flex,宽度设置为auto。当然,如果是上述的结构则不会有这个问题,但遇到大数据渲染,还是困扰我了一下午。
首先在需要在拖动的元素上绑定draggable属性,除了<a>和<img>标签设默认为true,其他元素都需要设置下,然后是三个事件dragend
、dragover
、drop
(用Vue写的,就不在事件前加on了)
注意dragover
需要去除默认行为,在事件中给上$event.preventDefault()
,否则拖曳时鼠标会有标志,使拖动无效。
drag的元素把值传到drop的位置,需要使用$event.dataTransfer.setData("node", transNodeData)
"node"
是相当于传递数据的变量名,需要先JSON.stringify()
methods:{ dragstart(e,nodeObj){ console.log('drag移动的点位',nodeObj.name,); let transData=JSON.stringify(nodeObj)//拖曳传递过去的数据先转为JSON格式 e.dataTransfer.setData("node",transData) }, dragover(e){ e.preventDefault() }, drop(e,nodeObj){ console.log('drop到的点位',nodeObj.name); let getData=JSON.parse( e.dataTransfer.getData("node")) console.log('获取了数据',getData); } }
了解了这一点,接下来要做的就是把获取的拖曳点位数据放到放置点位的children
数组中,并在dragend
事件中把拖曳点位在父节点children
数组中删除,节点的索引在dragstart
事件触发时就获取,并通过eventBus
这一组件通信方式传递给dragend
(也可以使用Vuex
)。
创建bus文件夹,新建index.js文件
import Vue from "vue" const busEvent= new Vue({ data(){ return{ dragNodeIndex:-1,//拖曳节点在父节点children数组中的index } }, created(){ this.$on("transDragNodeIndex", res=>{
//通过$on来监听$emit,需要确保自定义事件在触发前被监听,也就是订阅先于发布,否则无法监听到数据,我eventBus没怎么用过,这算是个坑 this.dragNodeIndex=res }) } }) export default busEvent
在组件中引入eventBus
,此时在dragstart
中通过$emit
触发自定义事件后,$on
就可以接收到这个数据,在dragend
中,可以通过eventBus
获取这一索引,然后在数组中删除
接下来就是做一些逻辑判断,例如父节点不能拖曳到子节点,先通过递归方式把父节点上所有子节点的name遍历进一个数组,如果drop位置的name
在数组中就表明父到子了,设置状态为true,
ifFatherDragToSon(dragObj,dropObj){//判断是否父节点移动到了子节点 if (dragObj.children.length === 0) return false; let newArr = []; function getAllName(dragObj) { newArr.push(...dragObj.children); if (dragObj.children.length === 0) { return; } else { for (let i = 0; i < dragObj.children.length; i++) { getAllName(dragObj.children[i]); } } } getAllName(dragObj); if (newArr.includes(dropObj)) { return true; } return false; }
通过eventBus
让dragend
事件获取状态,为true
直接return
拖曳到自身也不行,直接return。特意在拎壶冲点位下加了个子节点,主要就是为了验证通过节点在栈中的地址来判断,而不是依据name
属性
再一个就是提一下drag事件中的$event.dataTransfer.dropEffect
,可以获取的值为move
、copy
、none
、link
,下图中当dropEffect
为时拖曳点位消失了,其实就是执行了dragend
事件中的代码,而drop
事件中的代码未执行,所以这一步需要先做流程控制。另外说明,不同浏览器的默认dropEffect
也是不同的,比如360浏览器。
代码连接
关于vue实现拖拽树状图就介绍到这,上述实例具有一定的参考价值,感兴趣的朋友可以参考学习,希望能对大家有帮助,想要了解更多vue结构,大家可以关注群英网络其它相关文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
Promise是异步编程的一种解决方案,比传统的解决方案回调函数和事件更合理且更强大,这篇文章主要给大家介绍了关于如何一步步实现一个简易promise的相关资料,需要的朋友可以参考下
今天给大家分享的是关于vue图片裁剪组件的内容,下文对vue图片裁剪组件的使用有详细的介绍及示例代码,有需要的朋友可以参考。本文介绍的组件是基于vue-cropper二次封装,接下来我们一起了解看看。
目录前言案例回顾原型的拓展前言设计模式呢最多的可能是用到类,我们去通过类来封装一些实用的方法,通过设计模式去实现各个方法之间的解耦等,由于JS中的继承是用原型链继承的,所以原型模式是用原型实例指向创建对象的类,使用于创建新的对象的类共享原型对象的属性以及方法案例比如我们现在需要实现一个页面上的轮播图,可能需要用到对轮播
这篇文章主要介绍了vantUI 获得piker选中值的自定义ID操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
javascript取消选中事件的方法:可以通过删除事件处理程序来实现取消选中事件,例如【btn.onclick = null;】。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008