elementui中使用el-tree控件懒加载和局部刷新

目录
  • 使用el-tree控件懒加载和局部刷新
    • 懒加载
    • 局部刷新
  • element-ui el-tree lazy懒加载局部刷新的问题

使用el-tree控件懒加载和局部刷新

懒加载

按照 elementui官方文档示例,效果图

template部分,需要结合 lazy 和 load 一起使用

<el-tree
   show-checkbox
   node-key="id"
   lazy
   :load="loadNode"
   :props="defaultProps"
   v-loading="list.loading"
   ref="tree">
 </el-tree>

js 部分

export default {
  data () {
    return {
      list: {
        loading: false,
        isExpand: false
      },
      defaultProps: { // tree 控件的数据结构,需要设置 isLeaf
        children: 'children',
        label: 'name',
        isLeaf: 'leaf'
      },
      loading:false
    }
  },
  methods: {
    async loadNode(node, resolve) { // 懒加载
      if (node.level === 0) {
        return resolve(await this.getTagList())
      } else if (node.level === 1) {
        return resolve(await this.getTagApiList(node.label))
      } else {
        return resolve([]) // 防止该节点没有子节点时一直转圈的问题出现
      }
    },
    async getTagList () { // 获取所有接口所属模块 -> 第一层
      this.list.loading = true
      const res = await this.$API({
        name: 'getApiTagList',
        requireAuth: true
      })
      const tags = res.data.data
      tags.forEach((item, index) => { // 节点需要构建为 tree 的结构
        item.name = item.ta
        item.id = index
        item.leaf = false
      })
      this.list.loading = false
      return tags
    },
    async getTagApiList (tag) { // 查询模块下的接口列表 -> 第二层
      const res = await this.$API({
        name: 'getTagApiList',
        data: {
          tag
        },
        requireAuth: true
      })
      const results = res.data.data
      results.forEach(item => {
        item.name
        item.id
        item.leaf = true
      })
      return results
    },
  }
}

局部刷新

想要实现的效果是,新增节点,点击确定后局部刷新,渲染新数据

效果图

关键代码

<el-tree
  node-key="id"
  lazy
  :load="loadNode"
  :props="defaultProps"
  :expand-on-click-node="false"
  :check-on-click-node="true"
  v-loading="list.loading"
  @node-click="nodeClick"
  ref="tree">
</el-tree>
// 点击节点,把 node 保存下来,供局部刷新中的 node 使用
nodeClick (data, node) {
  this.curPath = data.path
  this.curNode = node
},
// 实现局部刷新,在点击弹窗处调用的
partialRefreshpartialRefresh (node) {
  node.loaded = false // 设置loaded为false;模拟一次节点展开事件,加载重命名后的新数据;
  node.expand() // 新建子节点是刷新一次本节点的展开请求,而重命名和删除则需要刷新父级节点的的展开事件,可以设置node.parent.loaded = false;node.parent.expand();
}

element-ui el-tree lazy懒加载局部刷新的问题

在项目开发中,使用el-tree  进行懒加载的时候,如果遇到需要进行添加 删除操作的时候,整体刷新数据体验会很不好,所以需要局部进行刷新,

我们可以通过找到树节点的形式,对当前展开的节点进行重新打开请求一次,以此来获取最新数据

 <el-tree
    lazy  
    ref="tree"
    :load="loadNode"
    :node-key="id"    
  >
 </el-tree>
methods: {
         refreshNodeBy(id){
             let node = this.$refs.tree.getNode(id); // 通过节点id找到对应树节点对象
             node.loaded = false;
             node.expand(); // 主动调用展开节点方法,重新查询该节点下的所有子节点
         }
     }

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 详解如何实现Element树形控件Tree在懒加载模式下的动态更新

    Element提供的Tree树形控件,可以用清晰的层级结构展示信息,还可以展开或折叠.Tree支持两种加载模式:一次性加载全部树节点和懒加载模式.所谓懒加载模式,是指当需要展开父节点时才渲染子节点.懒加载模式的应用场景适合树节点数据量大的情形,在一定程度上可以优化图形用户界面的响应效率以及提升用户体验.但是,懒加载模式对数据动态刷新应用需求的支持不尽如意.树形控件节点一旦展开就缓存在本地,后续不会再继续更新和刷新节点数据.本文将介绍如何实现Element树形控件Tree在懒加载模式下的动态更新.

  • Element-ui树形控件el-tree自定义增删改和局部刷新及懒加载操作

    需求: vue-cli项目树形控件:一级节点为本地节点,默认展开一级节点,增删改后局部刷新数据. 增加节点,点击确定后局部刷新,渲染新数据. 源码 element组件样式 <el-tree class="treeitems" :data="data" node-key="id" :props="defaultProps" :load="loadNode" lazy :default-expanded-

  • 基于element-ui封装可搜索的懒加载tree组件的实现

    引言 最近开发项目时遇到一个需求就是采用tree的方式展示以万为单位的数据,因为数据量大第一反应就是采用"懒加载"的方式实现,为了方便用户在庞大的数据量中快速定位到某个节点搜索功能也是必不可少的:因为采用"懒加载"数据,搜索当然也是远程搜索了:确定了需求当然第一时间就去网上找有没有小伙伴已经实现了相关组件,最后....,还是自己实现一个吧(由于公司采用的element-ui所以基于el-tree进行改造):[这只是自己实现的一种思路,希望大家多多指正] 1.懒加载树

  • elementui中使用el-tree控件懒加载和局部刷新

    目录 使用el-tree控件懒加载和局部刷新 懒加载 局部刷新 element-ui el-tree lazy懒加载局部刷新的问题 使用el-tree控件懒加载和局部刷新 懒加载 按照 elementui官方文档示例,效果图 template部分,需要结合 lazy 和 load 一起使用 <el-tree show-checkbox node-key="id" lazy :load="loadNode" :props="defaultProps&q

  • Jquery zTree 树控件异步加载操作

    zTree 是利用 JQuery 的核心代码,实现一套能完成大部分常用功能的 Tree 插件 兼容 IE.FireFox.Chrome 等浏览器 在一个页面内可同时生成多个 Tree 实例 支持 JSON 数据 支持一次性静态生成 和 Ajax 异步加载 两种方式 支持多种事件响应及反馈 支持 Tree 的节点移动.编辑.删除 支持任意更换皮肤 / 个性化图标(依靠css) 支持极其灵活的 checkbox 或 radio 选择功能 简单的参数配置实现 灵活多变的功能 异步加载的意思就是: 当点

  • Android使用控件ImageView加载图片的方法

    在 Android 加载图片一般使用 ImageView,这里简单记录一下这个控件的使用方法. 最简单就是在 xml 里直接使用 ImageView 标签: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="

  • jQuery 源代码显示控件 (Ajax加载方式).

    直接引用远程文件就可以显示源文件,确实解决了资源.在线演示:http://img.jb51.net/online/jquery_codeview/jquery_code.htm打包下载:http://xiazai.jb51.net/200905/yuanma/jquery_codeview.rar

  • Vue自定义图片懒加载指令v-lazyload详解

    Vue是可以自定义指令的,最近学习过程中遇见了一个需要图片懒加载的功能,最后参考了别人的代码和思路自己重新写了一遍.以下将详细介绍如何实现自定义指令v-lazyload. 先看如何使用这个指令: <img v-lazyload="imageSrc" > imageSrc是要加载的图片的实际路径. 为了实现这个指令,我们首先单独建立一个文件,名字为lazyload.js.并填写基本的代码,如下: //Vue 图片懒加载,导出模块 export default (Vue , o

  • vue2组件实现懒加载浅析

    一. 什么是懒加载 懒加载也叫延迟加载,即在需要的时候进行加载,随用随载. 二.为什么需要懒加载 在单页应用中,如果没有应用懒加载,运用webpack打包后的文件将会异常的大,造成进入首页时,需要加载的内容过多,延时过长,不利于用户体验,而运用懒加载则可以将页面进行划分,需要的时候加载页面,可以有效的分担首页所承担的加载压力,减少首页加载用时 三.如何与webpack配合实现组件懒加载 1.在webpack配置文件中的output路径配置chunkFilename属性 output: { pat

  • Struts2在打包json格式的懒加载异常问题

    Hibernate中如果出现了级联查询,就可能出现懒加载问题,比如我现在有个Account(管理员)类.Category(商品类别)和Product(商品)类,从左到右都是一对多的关系,而且从右到左都是设置了@ManyToOne(fetch=FetchType.LAZY).我现在要把商品信息查出来打包成json格式传到前台,我在后台使用查询语句为: from Product p left join fetch p.category where p.name like:name  这样就可以把Pr

  • 详解webpack + react + react-router 如何实现懒加载

    在 Webpack 1 中主要是由bundle-loader进行懒加载,而 Webpack 2 中引入了类似于 SystemJS 的System.import语法,首先我们对于System.import的执行流程进行简单阐述: Webpack 会在编译过程中扫描代码库时将发现的System.import调用引入的文件及其相关依赖进行单独打包,注意,Webpack 会保证这些独立模块及其依赖不会与主应用的包体相冲突. 当我们访问到这些独立打包的组件模块时,Webpack 会发起 JSONP 请求来

  • React 路由懒加载的几种实现方案

    这篇文字简单的介绍了React在路由懒加载方面的几种实现方案. 传统的两种方式 import() 符合ECMAScript提议的import()语法,该提案与普通 import 语句或 require 函数的类似,但返回一个 Promise 对象.这意味着模块时异步加载的 webpack v2+ 使用 使用方式 function component() { return import( /* webpackChunkName: "lodash" */ 'lodash').then(_

随机推荐