lazy 属性为true 时生效
lazy ----> 是否懒加载子节点,需与 load 方法结合使用

isLeaf可以提前告知 Tree 某个节点是否为叶子节点,从而避免在叶子节点前渲染下拉按钮。

HTML部分

<el-tree
          class="filter-tree"
          ref="tree"
          accordion
          :data="leftData"
          @node-click="handleNodeClick"
          node-key="listId"
          :current-node-key="currentNodeKey"
          :highlight-current="true"
          :props="defaultProps"
          :default-expanded-keys="idArr"
          lazy
          :load="loadNode"
        >
          <span class="custom-tree-node" slot-scope="{ node, data }">
            <el-tooltip
              class="item"
              effect="dark"
              :content="node.label"
              placement="top-start"
            >
              <span :id="data.listId">{{ node.label }}</span>
            </el-tooltip>
          </span>
 </el-tree>

JS部分

import {
  getMenuList,
  getNodeMenuList,
  getDataList,
} from "@/api/index";
export default {
data() {
    return {
      defaultProps: {
        children: "children",
        label: "name",
        isLeaf: "isLeaf",
      },
      currentNodeKey: "",
      leftData:[],
    }
  },
  methods:{
	// 懒加载获取数据
    loadNode(node, resolve) {
      if (node.level === 0) {// 第一层数据
      getMenuList({}).then((res) => {
      //左面导航栏省份信息
      if (res.data.resp_code == "200") {
        let data = res.data.datas;
        for (let key in data) {
          this.leftData.push({
            name: key,
            listId: key,
          });
        }
      }
    });
        return resolve(this.leftData);
      }
      if (node.level === 1) {// 第二层数据
        let provinceName = {
          provinceName: node.label, //上海
        };
        let twoList = [];
        getNodeMenuList(provinceName).then((res) => {
          res.data.datas.forEach((items) => {
            twoList.push({
              listId: items.listID,
              name: items.nodeName,
              provinceName: items.provinceName,
              children: [],
            });
            twoList.isLeaf = true;
          });
        });
        setTimeout(() => {
          resolve(twoList);
        }, 1000);
      }
      if (node.level == 2) {//第三层数据
        let obj = {
          nodeName: node.data.name,
          provinceName: node.data.provinceName,
        };
        let children = [];
        getDataList(obj).then((res) => {
          if (res.data.resp_code == "200") {
            res.data.datas.forEach((item, index) => {
              node.data.children.push({
                description: item.description,
                links: item.links,
                listId: item.listId,
                name: item.name,
                provinceName: item.provinceName,
                isLeaf: true,// 判断是不是子节点(最后一层数据 是否显示下拉图标) 如果不显示下拉图标为true 如果显示就可以不写
              });
            });
          }
        });
        resolve(node.data.children);
      }
      if (node.level > 2) {
        resolve([]);
      }
    },
}
}

element ui 中 el-tree 实现懒加载

在上次 element UI 中的 el-tree 实现 checkbox 单选框功能,及 bus 传递参数的方法 篇章中有提到 le-tree 的懒加载的功能,正好今天有时间来补充一下,让我们嗨起来 🤪

html 部分

下面 el-tree 标签中属性的介绍这里只介绍 props 、lazy、load属性 ,其他属性在上面链接的文章中有说明
1、props:绑定你定义的 props 变量,这里的 props变量是个对象,里面有几个键值:label、children、disabled(只有tree中带有checkbox才需要)、isLeaf(分别代表什么意思,下面的 data 部分有说明)。
2、lazy:为是否启用来加载的树型结构,true为启用,false为禁用,默认true。
3、load:lazy为true的时候生效,用来懒加载加载节点的方法,请求树的数据和逻辑处理都在这个方法汇总进行,下面的事件方法部分会有说明。

 <el-tree
   :props="props"
   :load="loadNode"
   lazy
   node-key="id"
   :expand-no-click-node="true"
   ref="tree"
   show-checkbox
   :check-strictly="true"
   @check="checkClick"
 >
 </el-tree>

data 部分

注:
1、下面的提到的属性在后面事件方法部都会讲到具体怎样使用。
2、这里没有定义 disabled 属性,因为这里没有必要定义,事件中直接使用就行,后面事件方法部会有说明。

<script>
export default {
  data(){
    return{
      props:{
        // 用来控制展示节点内容的字段,根据后端数据自定义 label 值是什么
        label:'text',
        // 子级存放的位置,拼接数据时候把子级放到这里定义 childNodes 的字段中,字段名称自定义 注意:childNodes 是个数组。
        children:'childNodes',
        // 用来判断是否为最后一级子节点
        isLeaf:'lastNode',
        // 这里的 id 是用来关联上面 node-key="id" 因为这里的树使用 checkbox 所以用到了 node-key="id" 和 id, 正常的只是单纯加载tree的话是不需要的,看需求喽
        id:"id"
      }
    }
  }
};
</script>

方法事件部分

methods: {
    // 功能讲解
    /* 默认参数:
       node:每加载一次当前加载的节点的所有数据
       reslove:渲染数据的方法,把得到该节点的所有数据(数组)放到该方法中 return 出去,节点就能渲染出来了。
     */
    async loadNode(node, reslove) {
      /* 
        判断是跟节点还是子节点,
        当 node.level == 0 的时候就是 tree 的跟节点(第一层;
        当  node.level 不等于 0 的情况就是每一层的节点了,没必要一直判断 level 是多少级别,除非有特殊需求
       */
      if (node.level == 0) {
        // 这里是请求接口,根据自己的项目请求接口就可以。
        let { resultValue } = await getTree(`pwi81cf45a5d07801452018091900001,${this.$store.state.userInfo.cityId}/`)
        // 这里就提到了 props 对象中的 disabled 属性的用法,通过找到请求接口找到满足条件的数据,然后这个给满足条件的数据添加一个 disabled = true 就可以实现 checkbox 禁用的效果了。
        resultValue.nodes[0].exValue == "" || resultValue.nodes[0].exValue == 'DYDJ' ? resultValue.nodes[0].disabled = true : null
        // 将请求回来的数据放到 reslove() 方法中渲染出来。
        return reslove(resultValue.nodes)
      } else {
        let endType = node.data.itemType.split('#')[1];
        let { resultValue } = await getTree(`pwi81cf45a5d07801452018091900001,${node.data.id}/${endType}`)
        /* 
          这里就是 props 对象中 isLeaf 属性的用法,上看我们定义的 isLeaf=‘lastNode',
          通过循环请求回来的数据,hasChildren 值为 flase (这个值一般都是后端设置数据的时候有带,至于是什么字段就得看后端是怎么定义的),用来判断是否还有下一级别, 
          当 hasChildren 值为 flase 的时候就可以给 请求回来的数据中添加一个 lastNode = true 的键值了,这就在你点开改节点的父级的时候就不回有提示 ,还能展开的三角箭头了。
        */
        resultValue.nodes.forEach(item => {
          item.hasChildren == false ? item.lastNode = ture : null
        });
        /* 
          这里是 props 对象中 children: 'childNodes' 属性的用法,因为是懒加载每次求情回来的数据都是没有和上面的数据有关联的一个数组,这时用想通过 el-tree 来实现树型结构的话我们就要拼装数据,将去回来的数据拼装到 当前节点的 childNodes 键值当中即可
        */
        node.data.childNodes = resultValue.nodes
        resultValue.nodes[0].exValue == "" || resultValue.nodes[0].exValue == 'DYDJ' ? resultValue.nodes[0].disabled = true : null
        return reslove(resultValue.nodes)
      }
    },
    // 套用模版
    async loadNode(node, reslove) {
      if (node.level == 0) {
        let res = await getData()
        return reslove(res.data)
      } else {
        let res = await getData()
        // 判断是否为最底层节点 根据自己接口返回的数据判断即可
        res.data.forEach(item => {
          item.hasChildren == false ? item.lastNode = ture : null
        });
        return reslove(res.data)
      }
    },
  },

到此这篇关于vue2 elementUI的el-tree的懒加载的文章就介绍到这了,更多相关vue2 elementUI懒加载内容请搜索Devmax以前的文章或继续浏览下面的相关文章希望大家以后多多支持Devmax!

vue2+elementUI的el-tree的懒加载功能的更多相关文章

  1. swift实现懒加载

    在swift中使用lazy描述符号可以实现属性的懒加载

  2. swift lazy 懒加载

    我们在使用lazy作为属性修饰符时,只能声明属性是变量。另外我们需要显式地指定属性类型,并使用一个可以对这个属性进行赋值的语句来在首次访问属性时运行。

  3. Swift中闭包,懒加载,单例的写法区别

    闭包闭包的参数和返回值都写在大括号里面,以”in”分隔开闭包内的代码块,如果闭包的参数和返回值都为空的话,”()->()in”就可以省略,下面是几种常见的闭包写法:最简单的闭包:有参数的闭包声明方法:方式1方式2,最外层括号可以前移到闭包名后面方式3懒加载:在Swift中,懒加载本质就是一个闭包,在前面加上lazy关键字,在需要这个属性的时候,会执行后面的闭包,并且把闭包的返回值记录下来,下次再次

  4. Swift- lazy 懒加载

  5. swift学习日志—— lazy懒加载

    在其他语言中懒加载的情况是很常见的。在Swift中我们使用在变量属性前加lazy关键字的方式来简单地指定延时加载。相比起在Objective-C中的实现方法,现在的lazy使用起来要方便得多。另外一个不太引起注意的是,在Swift的标准库中,我们还有一组lazy方法,它们的定义是这样的:这些方法可以配合像map或是filter这类接受闭包并进行运行的方法一起,让整个行为变成延时进行的。

  6. 从零学习Swift&lt;6&gt;

    构造函数convenience便利构造函数默认情况下,所有的构造方法都是指定构造函数Designatedconvenience关键字修饰的构造方法就是便利构造函数便利构造函数具有以下特点:可以返回nil只有便利构造函数中可以调用self.init()便利构造函数不能被重写或者super便利构造函数应用场景根据给定参数判断是否创建对象,而不像指定构造函数那样必须要实例化一个对象出来在实际开发中,可以

  7. Swift构造函数

    1.构造函数:给属性开辟内存空间给属性设置初始值最终目标创建一个对象用init构造函数参数有可能不同//定义属性使用var是我们开发需要的varname:String//可选属性-默认等于nil可以不需要在构造函数里进行初始化title属性没有分配内存空间在其他地方设置值的时候才需要分配内存空间vartitle:String?

  8. swift - lazy load

    swift中懒加载必须使用var关键字来定义延迟加载的属性,不能使用let关键字,因为常量必须在实例构建时赋值。懒加载常见格式:后面通过等号赋值一个闭包,闭包后面必须跟上(),如果闭包是用于懒加载,那么in之前的代码都可以省略,包括in在内比如也可以通过函数形式进行懒加载,比如

  9. swift之UITableView的使用

    下面我们一步一步从0开始写一个tableView。注意:1.协议的写法,不需要写。意思就是把什么当作什么,在上面的代码中,由于方法dequeueReusableCellWithIdentifier的返回值是AnyObject,所以需要通过as告诉编译器这实际上是一个UITableViewCell。也是一样的道理。

  10. swift编程语言简单开发二维码扫描

    )类型8.do{9.letinput=tryAVCaptureDeviceInput10.returninput11.}catch{12.print13.returnnil14.}15.}()16.//创建会话/输出比较简单只需要创建一个对象17.privatelazyvarsession:AVCaptureSession=AVCaptureSession()18.//创建输出设备19.privatelazyvardeviceOutput:AVCaptureMetadataOutput=AVCapture

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部