问题:
子节点修改删除后,子节点视图不刷新
初次解决办法:
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);