Element Plus中el-tree组件默认选中第一个节点的实现方法

Element Plus中el-tree组件默认选中第一个节点的实现方法

使用setCurrentKey API(推荐)

在Element Plus的el-tree组件中,实现默认选中第一个节点是常见的交互需求。本文将详细介绍两种实现方法,帮助开发者快速掌握相关技术要点。

setCurrentKey是Element Plus提供的官方API,通过设置当前节点的key值实现选中效果。该方法需要配合highlight-current属性和node-key使用。

cpp 复制代码
<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>el-tree默认选中</title>
  <link rel="stylesheet" href="https://unpkg.com/element-plus/dist/index.css">
  <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
  <script src="https://unpkg.com/element-plus"></script>
</head>
<body>
  <div id="app">
    <el-tree
      ref="treeRef"
      :data="treeData"
      node-key="id"
      :props="defaultProps"
      highlight-current
      @node-click="handleNodeClick"
    ></el-tree>
  </div>

  <script>
    const { createApp, ref, onMounted } = Vue;
    const { ElTree } = ElementPlus;

    createApp({
      setup() {
        const treeRef = ref(null);
        const treeData = ref([
          {
            id: 1,
            label: '一级节点 1',
            children: [
              { id: 4, label: '二级节点 1-1' },
              { id: 5, label: '二级节点 1-2' }
            ]
          },
          { id: 2, label: '一级节点 2' },
          { id: 3, label: '一级节点 3' }
        ]);

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

        const handleNodeClick = (data) => {
          console.log('节点点击:', data);
        };

        onMounted(() => {
          // 默认选中第一个节点
          if (treeData.value.length > 0) {
            treeRef.value.setCurrentKey(treeData.value[0].id);
          }
        });

        return {
          treeRef,
          treeData,
          defaultProps,
          handleNodeClick
        };
      }
    }).use(ElementPlus).mount('#app');
  </script>
</body>
</html>

关键点说明

  1. 必须设置node-key属性,指定节点唯一标识字段
  2. 需要添加highlight-current属性以高亮显示当前选中节点
  3. 操作时机应在组件挂载完成后(onMounted生命周期)

DOM操作模拟点击(兼容旧版)

对于特殊场景或旧版本兼容,可通过DOM操作模拟点击第一个节点实现选中效果。

cpp 复制代码
<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>el-tree默认选中(兼容版)</title>
  <link rel="stylesheet" href="https://unpkg.com/element-plus/dist/index.css">
  <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
  <script src="https://unpkg.com/element-plus"></script>
</head>
<body>
  <div id="app">
    <el-tree
      :data="treeData"
      node-key="id"
      :props="defaultProps"
      :default-expanded-keys="expandedKeys"
      @node-click="handleNodeClick"
    ></el-tree>
  </div>

  <script>
    const { createApp, ref, watch, nextTick } = Vue;

    createApp({
      setup() {
        const treeData = ref([
          {
            id: 1,
            label: '一级节点 1',
            children: [
              { id: 4, label: '二级节点 1-1' },
              { id: 5, label: '二级节点 1-2' }
            ]
          },
          { id: 2, label: '一级节点 2' },
          { id: 3, label: '一级节点 3' }
        ]);

        const expandedKeys = ref([]);
        const defaultProps = {
          children: 'children',
          label: 'label'
        };

        const handleNodeClick = (data) => {
          console.log('节点点击:', data);
        };

        // 设置默认展开第一个节点
        if (treeData.value.length > 0) {
          expandedKeys.value = [treeData.value[0].id];
        }

        // 监听数据变化后模拟点击
        watch(treeData, () => {
          nextTick(() => {
            const firstNode = document.querySelector('.el-tree-node__content');
            if (firstNode) firstNode.click();
          });
        }, { immediate: true });

        return {
          treeData,
          expandedKeys,
          defaultProps,
          handleNodeClick
        };
      }
    }).use(ElementPlus).mount('#app');
  </script>
</body>
</html>

注意事项

  1. 需配合default-expanded-keys确保第一个节点可见
  2. 操作时机应在DOM更新完成后(nextTick
  3. 性能影响较大,不推荐常规使用

方法对比

相关推荐
_OP_CHEN2 小时前
【前端开发之CSS】(六)CSS 弹性布局(Flex)完全指南:从入门到精通,搞定所有布局需求
前端·css·html·flex布局·弹性布局·界面美化·页面开发
雄狮少年2 小时前
简单react agent(没有抽象成基类、子类,直接用)--- langgraph workflow版 ------demo1
前端·python·react.js
css趣多多2 小时前
组件没有原生事件
前端·javascript·vue.js
IT陈图图2 小时前
Flutter × OpenHarmony 实战:优雅构建确认对话框的组件化方案
开发语言·javascript·flutter
雨季6662 小时前
Flutter 三端应用实战:OpenHarmony 简易文本末尾字符查看器开发指南
开发语言·javascript·flutter
小小弯_Shelby2 小时前
el-form表单简洁有效地解决新增与查看详情共用一个页面问题,控制el-form的disabled设置和修改样式
前端·vue.js·elementui
0思必得02 小时前
[Web自动化] 数据抓取、解析与存储
运维·前端·爬虫·selenium·自动化·web自动化
xiaoxue..2 小时前
全栈项目 学习日记 (第一章)
前端·react.js·面试·vite
chen_song_2 小时前
Agent 经典范式构建之 ReAct (Reasoning and Acting): 一种将“思考”和“行动”紧密结合的范式,让智能体边想边做,动态调整
前端·react.js·前端框架