当前位置: 首页 > news >正文

【elementui】记录解决el-tree开启show-checkbox后,勾选一个叶结点后会自动折叠的现象

第一种解决方案:设置default-expand-keys的值为当前选中的key值即可

<el-treeref="tree"class="checkboxSelect-wrap":data="treeData"show-checkboxnode-key="id":expand-on-click-node="true":props="defaultProps":accordion="false":default-checked-keys="defaultCheckedKeys":default-expand-keys="defaultExpandKeys":default-expand-all="false"@node-click="handleNodeClick"@check="handleCheckChange"
>
</el-tree>data() {return {defaultExpandKeys: [],}
},
computed: {// 当前选中的所有key值checkedKeys() {return this.$refs.tree.getCheckedKeys()},
},
methods() {handleCheckChange() {// 每次勾选后都把当前选中的所有key值给defaultExpandKeys this.defaultExpandKeys = this.checkedKeys}
}

第二种解决方法:使用getNode()找到当前点击的节点的expanded值,改变他,不让它为false折叠

之所以有第二种方法不用default-expand-keys的原因是:

在使用default-expand-keys之后,会出现一个现象:由于我的页面还有其他el-checkbox,这就造成了明明与el-tree无关,且el-tree的叶子节点是折叠的,但只要el-tree里面的某个节点是全选状态,勾选el-checkbox的时候,就会触发el-tree的叶结点自动展开的现象。

发生该现象的原因:
由于我的el-tree不确定接口数据有多少个,所以是循环出来的,会有两个以上的el-tree组件在同一个div里面,这就造成了使用default-expand-keys虽然可以解决勾选一个叶结点后会自动折叠的现象,但是当前default-expand-key我给的值是所有el-tree的getCheckedKeys()拿到的key值list。但我尝试了即使只给default-expand-keys赋值每个el-tree的getCheckedKeys(),还是会出现该现象。

如图所示:点击不限的瞬间,成长、平衡、价值的所有子结点突然全部展开了
在这里插入图片描述

此处我将expand-on-click-node设置了为false,不再使用该属性使得点击节点展开子结点

<el-treeref="tree"class="checkboxSelect-wrap":data="treeData"show-checkboxnode-key="id":expand-on-click-node="false":props="defaultProps":accordion="false":default-checked-keys="defaultCheckedKeys":default-expand-all="defaultExpand"@node-click="handleNodeClick"@check="handleCheckChange"
>
</el-tree>

在node-click事件中调用expand()展开节点:必须写nextTick,不然不生效;注释掉的那段可以用于点击节点、展开该节点下的子节点,就是和:expand-on-click-node="true"属性一个意思;但是不能保证点击叶结点时,该叶结点的上层节点保持展开的状态,没注释的那段,就可以达到该效果。

handleNodeClick(data, node, self) {this.$nextTick(() => {let currentNode = this.$refs.tree.getNode(data.id)if(!currentNode.parent.expanded) {currentNode.parent.expand(function(){for(let i=0; i< currentNode.parent.childNodes.length; i++){currentNode.parent.childNodes[i].expand()}})}// if(!currentNode.expanded){//   currentNode.expand(function(){//     for(let i=0; i< currentNode.childNodes.length; i++){//       currentNode.childNodes[i].expand()//     }//   })// }else {//   currentNode.expanded = false  // }})
},
http://www.lryc.cn/news/391048.html

相关文章:

  • 用Vue3和Plotly.js绘制交互式3D烛形图
  • git上传文件
  • Redis 7.x 系列【16】持久化机制之 AOF
  • 使用 PostGIS 生成矢量图块
  • WebSocket 心跳机制如何实现
  • Docker 容器连接
  • 【C语言】continue 关键字
  • Taro + vue3 中微信小程序中实现拉起支付
  • 003-GeoGebra如何无缝嵌入到PPT里
  • AI:开发者的朋友还是对手?
  • 如何在Android Studio中查看APP客户端日志
  • 2024微信小程序期末大作业-点奶茶微信小程序(后端nodejs-server)(附下载链接)_微信小程序期末大作业百度网盘下载
  • Qt:4.信号和槽
  • Ubuntu20.04更新GLIBC到2.35版本
  • Qt 实战(7)元对象系统 | 7.1、简介
  • iOS 真机打包,证书报错No signing certificate “iOS Distribution” found
  • 2024年7月3日 (周三) 叶子游戏新闻
  • linux守护进程生命周期管理-supervisord
  • rtpengine_mr12.0 基础建设容器运行
  • 逐步深入:掌握sklearn中的增量学习
  • 【机器学习】机器学习与图像识别的融合应用与性能优化新探索
  • Unity射击游戏开发教程:(29)躲避敌人的子弹射击
  • SpringCloud Gateway 网关获取或修改接口响应数据
  • 【课程总结】Day13(上):使用YOLO进行目标检测
  • 老年生活照护实训室:探索现代养老服务的奥秘
  • python-字典
  • 使用java stream对集合中的对象按指定字段进行分组并统计
  • 03.C1W2.Sentiment Analysis with Naïve Bayes
  • 一个强大的分布式锁框架——Lock4j
  • HarmonyOS - 通过.p7b文件获取fingerprint