el-tree 点击父节点无效,只能选中子节点

背景:

el-tree树形控件点击的时候,我们不希望点击父节点,只希望点击子节点触发效果。

实际使用示例:摄像头树状图,根据不同市级区域划分,我们只希望点击子节点【摄像头】有效,点击具体的摄像头调取网络接口,点击市级区域不调取接口。

官网示例:

官网示例代码:

javascript 复制代码
<template>
  <el-tree
    style="max-width: 600px"
    :data="data"
    :props="defaultProps"
    default-expand-all
    @node-click="handleNodeClick"
  />
</template>

<script lang="ts" setup>
interface Tree {
  label: string
  children?: Tree[]
}

const handleNodeClick = (data: Tree) => {
  console.log(data)
}

const data: Tree[] = [
  {
    label: 'Level one 1',
    children: [
      {
        label: 'Level two 1-1',
        children: [
          {
            label: 'Level three 1-1-1',
          },
        ],
      },
    ],
  },
  {
    label: 'Level one 2',
    children: [
      {
        label: 'Level two 2-1',
        children: [
          {
            label: 'Level three 2-1-1',
          },
        ],
      },
      {
        label: 'Level two 2-2',
        children: [
          {
            label: 'Level three 2-2-1',
          },
        ],
      },
    ],
  },
  {
    label: 'Level one 3',
    children: [
      {
        label: 'Level two 3-1',
        children: [
          {
            label: 'Level three 3-1-1',
          },
        ],
      },
      {
        label: 'Level two 3-2',
        children: [
          {
            label: 'Level three 3-2-1',
          },
        ],
      },
    ],
  },
]

const defaultProps = {
  children: 'children',
  label: 'label',
}
</script>

备注:从上面这个示例我们可以知道,点击父节点或者点击子节点都会触发节点点击事件,即触发节点点击事件@node-click="handleNodeClick"

要想仅仅点击子节点触发事件@node-click="handleNodeClick",需要在handleNodeClick事件内部判断点击的是否是子节点或者父节点,满足条件在执行,否则不执行。

实际效果图:

备注:在这个实际代码中,我们就可以判断type=== 100是否满足条件,满足的执行,不满足的不执行。

相关推荐
张3蜂7 分钟前
深入理解 Python 的 frozenset:为什么要有“不可变集合”?
前端·python·spring
无小道7 分钟前
Qt——事件简单介绍
开发语言·前端·qt
广州华水科技9 分钟前
GNSS与单北斗变形监测技术的应用现状分析与未来发展方向
前端
code_YuJun32 分钟前
corepack 作用
前端
千寻girling32 分钟前
Koa.js 教程 | 一份不可多得的 Node.js 的 Web 框架 Koa.js 教程
前端·后端·面试
全栈前端老曹34 分钟前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
code_YuJun34 分钟前
pnpm-workspace.yaml
前端
天才熊猫君37 分钟前
“破案”笔记:iframe动态加载内容后,打印功能为何失灵?
前端
五月君_1 小时前
炸裂!Claude Opus 4.6 与 GPT-5.3 同日发布:前端人的“自动驾驶“时刻到了?
前端·gpt
Mr Xu_1 小时前
前端开发中CSS代码的优化与复用:从公共样式提取到CSS变量的最佳实践
前端·css