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

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

问题点

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

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

我先选中当前节点

然后点击间隙,如下图

解决方案

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

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

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

注意

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

相关推荐
之歆21 分钟前
DAY_21JavaScript 深度解析:数组(Array)与函数(Function)(一)
前端·javascript
XinZong1 小时前
【AI社交】基于OpenClaw自研轻量化AI社交平台实战
前端
Le_ee1 小时前
ctfweb:php/php短标签/.haccess+图片马/XXE
开发语言·前端·php
爱上好庆祝1 小时前
学习js的第七天(wed APIs的开始)
前端·javascript·css·学习·html·css3
KaMeidebaby2 小时前
卡梅德生物技术快报|冻干工艺开发:注射用心肌肽全流程参数优化与工程化方案
前端·其他·百度·新浪微博
ooseabiscuit2 小时前
Laravel6.x核心优化与特性全解析
android·开发语言·javascript
哆啦A梦15883 小时前
20, Springboot3+vue3实现前台轮播图和详情页的设计
javascript·数据库·spring boot·mybatis·vue3
Moment3 小时前
面试官:如果产品经理给你多个需求,怎么让AI去完成❓❓❓
前端·后端·面试
每天吃饭的羊3 小时前
JSONP
前端
gogoing3 小时前
ESLint 配置字段说明
前端·javascript