el-tree 懒加载 loadNode

el-tree 是 Element UI 提供的树形组件,其懒加载功能通过 loadNode 方法实现,可以在用户展开节点时动态加载子节点数据,避免一次性加载大量数据。下面介绍 loadNode 的具体用法和示例。

基本用法

loadNodeel-tree 的一个重要属性,用于定义节点加载的回调函数。当用户展开一个节点时,会触发该回调并传入当前节点的信息,开发者可根据这些信息异步加载子节点数据。

核心参数
  • node:当前点击的节点对象,包含节点的层级、数据等信息。
  • resolve:回调函数,用于将加载的子节点数据传递给树组件。

【完整代码】

html 复制代码
<template>
  <el-tree
    :load="loadNode"
    lazy
    :props="treeProps"
    @node-click="handleNodeClick">
  </el-tree>
</template>

<script>
export default {
  data() {
    return {
      treeProps: {
        label: 'name', // 指定节点标签为数据中的 name 字段
        children: 'children' // 指定子节点为数据中的 children 字段
      }
    };
  },
  methods: {
    // 懒加载回调函数
    loadNode(node, resolve) {
      // 根节点(node.level === 0)通常是初始节点
      if (node.level === 0) {
        // 模拟异步加载根节点数据
        setTimeout(() => {
          const data = [
            { id: 1, name: '节点1', leaf: false },
            { id: 2, name: '节点2', leaf: false }
          ];
          resolve(data); // 将数据传递给树组件
        }, 500);
      } else {
        // 非根节点,根据父节点加载子节点
        setTimeout(() => {
          // 模拟根据父节点ID加载子节点数据
          const childData = [
            { id: `${node.data.id}-1`, name: `子节点1-${node.data.id}`, leaf: true },
            { id: `${node.data.id}-2`, name: `子节点2-${node.data.id}`, leaf: true }
          ];
          resolve(childData);
        }, 500);
      }
    },
    // 节点点击事件处理
    handleNodeClick(data) {
      console.log('点击节点:', data);
    }
  }
};
</script>
相关推荐
Dragon Wu7 小时前
Electron Forge集成React Typescript完整步骤
前端·javascript·react.js·typescript·electron·reactjs
芳草萋萋鹦鹉洲哦7 小时前
【Tailwind】动画解读:Tailwind CSS Animation Examples
前端·css
华仔啊7 小时前
jQuery 4.0 发布,IE 终于被放弃了
前端·javascript
一心赚狗粮的宇叔7 小时前
03.Node.js依赖包补充说明及React&Node.Js项目
前端·react.js·node.js
子春一7 小时前
Flutter for OpenHarmony:音律尺 - 基于Flutter的Web友好型节拍器开发与节奏可视化实现
前端·flutter
JarvanMo7 小时前
150万开发者“被偷家”!这两款浓眉大眼的 VS Code 插件竟然是间谍
前端
亿元程序员7 小时前
大佬,现在AI游戏开发教程那么多,你不搞点卖给大学生吗?
前端
未来龙皇小蓝8 小时前
RBAC前端架构-02:集成Vue Router、Vuex和Axios实现基本认证实现
前端·vue.js·架构
晓得迷路了8 小时前
栗子前端技术周刊第 116 期 - 2025 JS 状态调查结果、Babel 7.29.0、Vue Router 5...
前端·javascript·vue.js
淡忘_cx8 小时前
使用Jenkins自动化部署vue项目(2.528.2版本)
vue.js·自动化·jenkins