vue-表格树结构-懒加载-解决子节点修改删除后,不刷新的问题

本文介绍了在Vue.js中处理表格树结构时遇到的子节点修改或删除后视图不刷新的问题。首先尝试了通过刷新页面来解决,但导致了节点折叠和全量刷新的不良用户体验。最终采用了一种新的解决方案,实现了只刷新受影响的子节点,保持了良好的用户体验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:
子节点修改删除后,子节点视图不刷新
初次解决办法:

export default {
  inject: ['sizeReload'],
  }

子节点变化后执行:

this.sizeReload()

子节点变化后,进行页面的刷新操作,但是刷新后,节点会自动折叠,且全部刷新用户体验不好。

最终解决办法:

效果图:
在这里插入图片描述
data:

maps: new Map(),

点击展开:

// 数据懒加载
    load(tree, treeNode, resolve) {
      const pid = tree.tid;
      this.maps.set(pid, { tree, treeNode, resolve }); //将当前选中节点数据存储到maps中
      this.$api
        .post(this.$lesUiPath.tmProvinceFind, { tid: tree.tid })
        .then(result => {
          if (result.status == 200) {
            resolve(result.data);
          }
        });
    },

增加、删除、修改-子节点:
this.$refs.table.$refs.tree.store.states.lazyTreeNodeMap—根据实际情况写

const pid = data.tmProvinceId; //取出当前删除行的父级id
const { tree, treeNode, resolve } = this.maps.get(pid); //根据pid取出对应的节点数据
this.$set(
  this.$refs.table.$refs.tree.store.states.lazyTreeNodeMap,
  pid,
  []
); //将对应节点下的数据清空,从而实现数据的重新加载
this.load(tree, treeNode, resolve);
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值