tree组件点击节点间隙的异常问题分析

本文分享的是近期项目中遇到一个问题:element plus中的tree组件,点击上下相邻两个树节点的间隙,导致树收起节点且切换选中节点为根节点的问题。

问题点

项目中我们对树节点设置了margin-top/margin-bottom属性,使得树节点间出现了间隙,然后当我们操作节点的选中状态时,点击到间隙位置,树整体收起到了根节点,并且选中了根节点。这个问题是测试发现的。

后续我在element plus官网中的tree组件进行尝试,也发现了问题所在,不过并没有收起节点(我设置了margin-top,原本没有间隙)。

我先选中当前节点

然后点击间隙,如下图

解决方案

采用自定义节点的方式,然后加入一个遮罩层的元素,通过定位的方式遮挡住间隙,从而是的对应的点击事件触发在遮罩层元素上

这里的div用作遮罩层,遮挡间隙。

点击事件的作用是完全阻止点击事件在间隙处的默认行为和事件传播

注意

以上是通过定位解决此问题的,要保障el-tree-node__content此元素设置了position:relative

相关推荐
玖笙&7 分钟前
✨万字解析解析:Vue.js优雅封装级联选择器组件(附源码)
前端·javascript·vue.js·前端框架
烟袅8 分钟前
深入理解 React 中 useState 与 useEffect
前端·javascript·react.js
行走的陀螺仪16 分钟前
前端基建从0到1搭建步骤清单(含工具选型+配置要点+落地注意事项)
前端·javascript·typescript·设计规范·前端工程化·规范化·前端基建
BD_Marathon19 分钟前
会话管理_Session
javascript
小白阿龙21 分钟前
脚手架启动失败(Vue CLI/Vite/Create React App)
前端·vue.js·react.js
鞋尖的灰尘25 分钟前
sdkman安装使用
前端
Aniugel31 分钟前
Vue国际化实现多语言方案
前端·vue.js·面试
帅帅哥的兜兜37 分钟前
猪齿鱼 table表单编辑
前端
白兰地空瓶37 分钟前
你以为树只是画图?不——它是算法面试的“隐形主角”
前端·javascript·算法