elementui tree 层级过多时,高亮状态无法选满整行

问题:

如上图所示,官方的tree组件,在层级很多时 elementui -tree 的高亮状态并没有选中整行。

(衍生库 vue-easy-tree 也会出现此问题)

原因:

(没有查看源码,只是根据dom简单定位了一下,实际可能并不是这个原因)

添加高亮状态的 div 并没有随着子级的展开而适应宽度,所有的tree-node 的宽度在初始化的时候就固定了。

解决方式:

复制代码
.el-tree-node{
    width: fit-content;
    min-width: var(--treeWidth);
  }

通过fit-content 可以将宽度随着内容撑开,而min-width 会保证没有那么多层级时也可以左右排布。

(treeWidth 表示的是整个tree 容器的宽度,要是需要留有间隙,可以减去 10 或者 20 像素)

加了以后则可以全行高亮了

缺点:

min-width 在某些条件下会显得多余,例如:

此时只需要tree根据弹窗自动铺满就好了,不用考虑min-width。

当然这个解决起来也不复杂,通过js计算一下父容器的宽度就好了

复制代码
mounted () {
    this.treeWidth = this.$refs['easy-tree']?.$el.offsetWidth - 15
},

第二天的ps:

好像不用js计算,min-width: 100% 就可以搞定了~

相关推荐
研☆香3 分钟前
JS中的三种显示弹窗
开发语言·前端·javascript
俩毛豆4 分钟前
HarmonyOS APP开发-一文讲清使用Web组件加载网页的三种方法-《精通HarmonyOS NEXT :鸿蒙App开发入门与项目化实战》读者福利
前端·华为·harmonyos
C_心欲无痕11 分钟前
Next.js 路由系统对比:Pages Router vs App Router
开发语言·前端·javascript
LawrenceLan14 分钟前
Flutter 零基础入门(二十二):Text 文本组件与样式系统
开发语言·前端·flutter·dart
运筹vivo@29 分钟前
攻防世界:Web_php_unserialize
前端·web安全·php
Jiangnan_Cai36 分钟前
【Electron】Windows 下打包遇到 dist/unpacked 文件内 electron.exe 文件缺失问题
前端·javascript·electron
自不量力的A同学37 分钟前
Electron 40.0.0 发布,跨平台桌面应用开发工具
前端·javascript·electron
Charlie_lll1 小时前
学习Three.js–材质(Material)
前端·three.js
Kratzdisteln1 小时前
【1902】预先生成完整的树状PPT结构
java·前端·powerpoint
深耕AI1 小时前
【wordpress系列教程】05 文章分类与标签
前端