el-tree实现懒加载

一、懒加载树结构

复制代码
<div class="hello" id="container">
    <el-tree
      ref="tree"
      node-key="id"
      :default-expanded-keys="[2]"
      current-node-key="2"
      :props="defaultProps"
      :check-strictly="true"
      @node-click="getChecked"
      @check="handleCheck"
      highlight-current
      :load="loadNode"
      lazy
    >
    </el-tree>
 </div>

data() {
   defaultProps: {
      // children: 'children',
      label: 'label',
       isLeaf: 'leaf'
    }
},
methods: {
    loadNode(node, resolve) {
      console.log('level:=====', node.level)
      if (node.level === 0) {
        return resolve([
          { id: 1, label: 'region' },
          { id: 2, label: 'region2' }
        ])
      }
      if (node.level > 1) return resolve([])

      setTimeout(() => {
        const data = [
          {
            id: 3,
            label: '一级 3',
            leaf: true
          },
          {
            id: 4,
            label: 'zone'
          }
        ]

        resolve(data)
      }, 500)
    }
}

二、懒加载并做数据回显

复制代码
<el-tree
      ref="tree"
      node-key="id"
      current-node-key="2"
      :props="defaultProps"
      :check-strictly="true"
      :show-checkbox="showCheckbox"
      :default-expanded-keys="allSelectOptions"  
      :default-checked-keys="remainIds"
      @node-click="getChecked"
      @check="handleCheck"
      highlight-current
      :load="loadNode"
      lazy
    >
 </el-tree>
// allSelectOptions--默认展开节点得key数组
// remainIds--默认选中key
// 1、defaultExpandAll 不可设置为默认展开,根据回显时,设置的default-expanded-keys?,
// 若设置默认展开值,则只加载第一次,剩下走el-tree自带的懒加载;
// 若未设置展开值,则首次需要全加载出来
data() {
    return {
      defaultProps: {
        // children: 'children',
        label: 'label',
        isLeaf: 'leaf'
      },
      remainIds: [3],
      allSelectOptions: [1]
    }
  }
相关推荐
烛阴7 小时前
从0到1掌握盒子模型:精准控制网页布局的秘诀
前端·javascript·css
七八书11 小时前
Vue3 组件通信全解析:从基础到进阶的实用指南
vue.js
用户38022585982411 小时前
vue3源码解析:模块总览
vue.js
Danny_FD11 小时前
React中可有可无的优化-对象类型的使用
前端·javascript
LeeAt11 小时前
从Promise到async/await的逻辑演进
前端·javascript
前端Hardy12 小时前
HTML&CSS:3D 轮播图全攻略
前端·javascript
前端Hardy12 小时前
7 个技巧助你写出优雅高效的 JavaScript 异步代码
前端·javascript·面试
等一个晴天丶12 小时前
element-ui elemant-plus el-tree展开按钮变成加减号
vue.js
HelloWord12 小时前
从零到一搭建vue3+ts项目
前端·vue.js
走向终结的前端13 小时前
vue中再搞一下SSE的使用
前端·javascript