Element Plus的el-tree-v2 组件实现仅叶子节点显示勾选框,并且只能单选

实现代码

html 复制代码
<template>
  <el-tree-v2
    :data="treeData"
    :props="defaultProps"
    node-key="id"
    ref="treeRef"
    show-checkbox
    :check-strictly="true"
    :expand-on-click-node="false"
    @node-click="handleNodeClick"
    @check="handleCheck"
  />
</template>

<script setup>
import { ref } from 'vue';

const treeData = ref([
  // ...树形数据
]);

const defaultProps = {
  children: 'children',
  label: 'label',
};

const treeRef = ref(null);

const handleNodeClick = (nodeData, node) => {
  // 如果是叶子节点,则选中它
  if (node.isLeaf) {
    treeRef.value.setChecked(nodeData, true, true);
  }
};

const handleCheck = (data, { checked }) => {
  // 处理单选逻辑
  if (checked) {
    // 清除其他选中的节点
    const checkedKeys = treeRef.value.getCheckedKeys();
    if (checkedKeys.length > 1) {
      treeRef.value.setCheckedKeys([data.id]);
    }
  }
};
</script>

<style scoped>
/* 样式穿透,隐藏非叶子节点的复选框 */
:deep(.el-tree-node) > .el-tree-node__content .el-checkbox .el-checkbox__inner {
  display: none;
}
:deep(.el-tree-node.is-leaf) > .el-tree-node__content .el-checkbox .el-checkbox__inner {
  display: inline-block;
}
</style>

实现思路

handleNodeClick 方法用于处理节点点击事件,如果点击的是叶子节点,则将其选中。

handleCheck 方法用于处理复选框的选中事件,确保只有一个叶子节点被选中。

使用 :check-strictly="true" 确保复选框的选择不会影响父子节点。

使用 :expand-on-click-node="false" 确保点击节点不会展开或折叠,这样点击叶子节点时不会触发展开操作。

相关推荐
刀法如飞9 小时前
TypeScript 数组去重的 20 种实现方式,哪一种你还不知道?
前端·javascript·算法
IT_陈寒9 小时前
Vite热更新失效?你可能漏了这个小细节
前端·人工智能·后端
海石9 小时前
面试官:说一下你现在使用的 AI IDE,什么,JoyCode 是什么?
前端·ai编程
彩票管理中心秘书长9 小时前
一次搞懂:在Vue里用Showdown渲染Markdown+KaTeX数学公式
前端
m0_738120729 小时前
应急响应(重点)——记一次某公司流量应急溯源分析(附带下载链接)
服务器·前端·数据库·安全·web安全·网络安全
前端Hardy10 小时前
pnpm 11.0 正式登场:安装起飞、安全拉满、彻底告别 npm 依赖
前端
PILIPALAPENG10 小时前
第4周 Day 1:智能体记忆系统——给 Agent 一个"大脑"
前端·人工智能·python
_风满楼10 小时前
TDD实战-会议室冲突检测的红绿重构循环
前端·javascript·算法
Rkgua10 小时前
JS中的惰性函数基本介绍
前端·javascript
客场消音器10 小时前
我用两周半 Vibe Coding 做了一个前额叶训练的微信小程序
前端·javascript·后端