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" 确保点击节点不会展开或折叠,这样点击叶子节点时不会触发展开操作。

相关推荐
I_Am_Me_12 分钟前
【JavaEE进阶】 JavaScript
开发语言·javascript·ecmascript
雯0609~19 分钟前
网页F12:缓存的使用(设值、取值、删除)
前端·缓存
℘团子এ22 分钟前
vue3中如何上传文件到腾讯云的桶(cosbrowser)
前端·javascript·腾讯云
学习前端的小z27 分钟前
【前端】深入理解 JavaScript 逻辑运算符的优先级与短路求值机制
开发语言·前端·javascript
星星会笑滴31 分钟前
vue+node+Express+xlsx+emements-plus实现导入excel,并且将数据保存到数据库
vue.js·excel·express
前端百草阁1 小时前
【TS简单上手,快速入门教程】————适合零基础
javascript·typescript
彭世瑜1 小时前
ts: TypeScript跳过检查/忽略类型检查
前端·javascript·typescript
FØund4041 小时前
antd form.setFieldsValue问题总结
前端·react.js·typescript·html
Backstroke fish1 小时前
Token刷新机制
前端·javascript·vue.js·typescript·vue
zwjapple1 小时前
typescript里面正则的使用
开发语言·javascript·正则表达式