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

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

实现代码

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


http://www.kler.cn/news/363946.html

相关文章:

  • sqli-labs靶场安装以及刷题记录-docker
  • 消息会话—发送消息自动滚动到最底部
  • GO excelize 读取excel进行时间类型转换(自动转换)
  • 后端消息推送方案方案(轮询,长轮询,websocket,SSE)
  • 【前端】如何制作一个自己的网页(18)定义列表
  • ImportError: DLL load failed while importing _rust: 找不到指定的模块。
  • MYSQL-SQL-04-DCL(Data Control Language,数据控制语言)
  • 若依框架vue3模板
  • 单例模式是一种常见的设计模式,确保一个类只有一个实例,并提供一个全局访问点。
  • Linux Redis查询key与移除日常操作
  • 尚硅谷redis 第97节 redisTmplate下答疑
  • 代码随想录算法训练营第二天| 209.长度最小的子数组 59.螺旋矩阵II 区间和 开发商购买土地
  • 身份证识别JAVA+OPENCV+OCR
  • ref属性的作用对象类型
  • 文件操作(1) —— 文件基础知识
  • 【C++】——list 容器的解析与极致实现
  • 修改IDEA中@author变量user内容
  • 开源软件搜索工具:Reddo
  • React是如何处理事件的?
  • linux 将已经启动的java应用的控制台日志输出出来, 不停应用的情况下
  • Java 使用 itextpdf 自定义 生成 pdf
  • CSS 网格布局
  • 前端发送请求格式
  • 2024昆明ICPC A. Two-star Contest(直观命名+详细注释)
  • SpringCloudAlibaba-Nacos
  • upload靶场sql靶场一点点见解