# el-tree过滤后树形全选问题

在el-tree中遇到过滤功能后,点击父节点仍会全选所有子节点,包括未显示的。为解决此问题,通过绑定@check-change事件并定义handleCheckChange方法尝试修正。然而,这导致过滤前已选中的子节点被取消选中。寻求解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

el-tree过滤后树形全选问题

el-tree过滤后点击一个父节点依旧会把它下面的所有显示或不显示的子节点全部勾选上,我希望只会勾选上当前父节点下显示的子节点,所以做出了如下修改。
给组件绑定方法 @check-change=“handleCheckChange”
然后定义方法:

  handleCheckChange(data) {
    if (data.children) {
      data.children.forEach((item) => {
        const node = (this.$refs.tree as any).getNode(item);
        if (!node.visible) {
          (this.$refs.tree as any).setChecked(item, false);
        }
      });
    }
  }

但是这样还存在问题,就是会把过滤前该父节点下已经勾选上的子节点的勾取消掉了,希望大佬们指点qwq

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值