element Tree组件懒加载

关键参数:lazyload


 <el-tree highlight-current node-key="id" :load="isLoad" lazy :props="defaultProps"></el-tree>
 

load 方法会在初始加载自动执行一次:


//isLoad 方法入参接收的node是element 组件自身的节点结构,node.data才是后端返回的节点数据,resolve是一个方法,用于渲染节点

async isLoad(node, resolve) {
  //如果展开第一级节点,从后台加载一级节点列表
  if (node.level == 0) {
    this.loadfirstnode(resolve);
  }
  //如果展开其他级节点,动态从后台加载下一级节点列表
  if (node.level >= 1) {
    this.loadchildnode(node, resolve);
    return resolve([]); // 加上这个,防止在该节点没有子节点时一直转圈的问题发生。
  }
},


//加载第一级节点
  async loadfirstnode(resolve) {
            let params = {
                level: 1,
            };
            let res = await getAreaListTree(params)
            return resolve(res);
        },
// 加载子节点
  async loadchildnode(node, resolve) {
            console.log(node.data)
            let params = {
                level: node.data.level + 1,
                id: node.data.id,
                allpath: node.data.allpath
            }
            let res = await getAreaListTree(params)
            return resolve(res);
        },
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值