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

el-tree 获取当前勾选节点的选中状态以及选中值对象 触发check-change多次事件问题原因

1.需求 现在需要一个树状结构的资产树 但是现在需求是 获取当前选中的值的状态是选中还是取消选中 然后再用当前选中 or 取消选中的值 进行 选中 or 取消选中的操作

一开始使用的是  check-change 方法

接收参数如图    但是我勾选父节点 或者 子节点后 他会打印一堆数据 是因为

当你触发了子节点的复选框,如果复选框为全选的状态,因为你的一次触发,导致变为半选的状态,导致会在触发一次父节点的复选框check-change。

反之,假如树节点的复选框是没有选择的状态,由于选择了子节点后,变成了半选的状态,又会触发一次check-change

再者,就是直接选择复选框的话,复选框假如是全选的状态的话,点击树节点的父节点的话,会改变子节点所有的选择,则会触发节点数数量+1(父节点)的check-change次数

总结: Element Plus 的 <el-tree> 组件在处理勾选状态时,会因为级联的勾选逻辑导致 check-change 事件多次触发。直接操作父节点的复选框会影响其所有子节点的勾选状态,从而触发每个子节点的 check-change 事件;而勾选或取消勾选子节点也可能会改变父节点的勾选状态,导致父节点的 check-change 事件被触发。

解决办法  1.

设置为true 但是这样子节点与父节点之间就没关联了 这样就违背了我们的初衷

解决办法  2.

 使用check 可以使用接收的参数来判断当前选中的状态 

  const isChecked = node.checkedKeys.includes(data.id);if (isChecked) {//勾选console.log('勾选');} else {//取消勾选console.log('取消勾选');}

 我们也可以使用 this.$refs.tree.getCheckedNodes() 来获取树节点上的所有勾选的节点过滤进行某些操作 

this.$refs.tree.getCheckedNodes()

 这是vue2 写法 vue3同理 

参考文章 : Element-plus el-tree 触发check-change多次事件

补充 :

 隐藏第一层节点 或者最后一层节点的 勾选框

//隐藏第一级   给el-tree 一个类名 stafftree   
::v-deep .stafftree > .el-tree-node > .el-tree-node__content .el-checkbox {display: none;
}
//隐藏最后一层节点::v-deep .el-tree-node {.is-leaf+.el-checkbox .el-checkbox__inner {display: none;}// .el-checkbox .el-checkbox__inner {//     display: none;// }}

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 【idea】idea配置gitee插件_简单使用
  • python网络爬虫之Urllib
  • 批量提取网页表格内容至excel文件
  • Cypress UI自动化之安装环境
  • Win10安装MongoDB(详细版)
  • 论文降痕降重全攻略:从技巧到工具,助你轻松应对学术挑战
  • BatchNorm LayerNorm
  • WEB-INF 泄露-RoarCTF-2019-EasyJava(BUUCTF)
  • 05_四旋翼飞行器姿态表示
  • Python爬虫+数据分析+数据可视化图形-爬取高校排名数据
  • linux高级编程(OSI/UDP(用户数据报))
  • 【小沐学Python】在线web数据可视化Python库:Bokeh
  • python实现http get pos download
  • HTML集成优雅的实时输入清除功能
  • C++ 容器:pair tuple
  • [微信小程序] 使用ES6特性Class后出现编译异常
  • 【node学习】协程
  • 【译】React性能工程(下) -- 深入研究React性能调试
  • android百种动画侧滑库、步骤视图、TextView效果、社交、搜房、K线图等源码
  • Android优雅地处理按钮重复点击
  • C++入门教程(10):for 语句
  • ComponentOne 2017 V2版本正式发布
  • HashMap ConcurrentHashMap
  • JavaScript 无符号位移运算符 三个大于号 的使用方法
  • Java深入 - 深入理解Java集合
  • JDK 6和JDK 7中的substring()方法
  • leetcode98. Validate Binary Search Tree
  • Puppeteer:浏览器控制器
  • Spring Boot快速入门(一):Hello Spring Boot
  • Spring-boot 启动时碰到的错误
  • spring学习第二天
  • 发布国内首个无服务器容器服务,运维效率从未如此高效
  • 回顾 Swift 多平台移植进度 #2
  • 记录:CentOS7.2配置LNMP环境记录
  • 技术胖1-4季视频复习— (看视频笔记)
  • 使用iElevator.js模拟segmentfault的文章标题导航
  • 线性表及其算法(java实现)
  • 职业生涯 一个六年开发经验的女程序员的心声。
  • CMake 入门1/5:基于阿里云 ECS搭建体验环境
  • # centos7下FFmpeg环境部署记录
  • # Panda3d 碰撞检测系统介绍
  • # 睡眠3秒_床上这样睡觉的人,睡眠质量多半不好
  • ###C语言程序设计-----C语言学习(3)#
  • $Django python中使用redis, django中使用(封装了),redis开启事务(管道)
  • $nextTick的使用场景介绍
  • (Repost) Getting Genode with TrustZone on the i.MX
  • (zz)子曾经曰过:先有司,赦小过,举贤才
  • (超详细)语音信号处理之特征提取
  • (四)图像的%2线性拉伸
  • (五)Python 垃圾回收机制
  • (一)appium-desktop定位元素原理
  • (转)ABI是什么
  • (转)winform之ListView
  • .NET Conf 2023 回顾 – 庆祝社区、创新和 .NET 8 的发布
  • .net core 调用c dll_用C++生成一个简单的DLL文件VS2008