vue+element?tree懶加載更新數(shù)據(jù)的示例代碼
使用element tree實現(xiàn)懶加載,更新某一節(jié)點的數(shù)據(jù)
1.tree 懶加載
只需要在el-tree標簽上面添加lazy,load屬性,load的接收是一個函數(shù)。這里貼上官網(wǎng)給出的方法


<el-tree :data="treeList" ref="tree" class="vue-tree" lazy :load="loadNode" :highlight-current="true" :node-key="nodeKey" @node-click="nodeClick" :expand-on-click-node="false" :props="defaultProps" ></el-tree>
2.load方法使用
// 懶加載獲取樹形結構
loadNode(node, resolve) {
//調用接口時,我們的需求是第一級傳參為0,后面為當前節(jié)點的唯一表示id,可以根據(jù)需求而定
// node.level為0時,就是tree的第一級
const spaceParentGuid = node.level === 0 ? 0 : node.data.spaceGuid
getDeviceLazyTree({ spaceParentGuid }).then(({ data }) => {
resolve(
data.data.map(item => {
return {
...item,
leaf: !item.hasChildren // 此參數(shù)用來判斷當前節(jié)點是否為葉子節(jié)點
}
})
)
})
},
3.leaf的作用
當我們使用的tree懶加載,只會加載到我們請求的那一層級,所以當我們在葉子節(jié)點請求時,請求完不會出現(xiàn)數(shù)據(jù),這樣的體驗就不是很好,這個時候就需要借助tree的props里面isLeaf的配置方法了

defaultProps: {
children: 'children',
label: 'spaceName',
isLeaf: 'leaf'
}
加上此字段,就可以清晰的看出哪些節(jié)點為葉子節(jié)點了
4.我們一旦使用懶加載的方式的話
那我們在對tree接口進行增刪改查時,及時刷新數(shù)據(jù)時,就會造成我們還需要從新獲取接口
其實如果我們仔細觀察的話,我們會發(fā)現(xiàn)已經(jīng)請求過的節(jié)點,我們收起,再次打開是不會請求接口的,這樣的話,我們可以這么做
/**
* 單獨刷新節(jié)點
* guid: 當前節(jié)點的父級唯一標識節(jié)點
*/
refreshTreeNode(guid) {
let node = this.$refs.tree.getNode(guid)
if (node) {
node.loaded = false
node.expand() // 主動調用展開節(jié)點方法,重新查詢該節(jié)點下的所有子節(jié)點
}
},Vue Element Ui 樹形表懶加載新增、修改、刪除等操作后局部數(shù)據(jù)更新
前言
element 樹表懶加載在每次對表格進行修改刪除等操作后需要刷新表格數(shù)據(jù)時都需要重新請求,在逐增展開加載,這樣對用戶來說不太友好所以我們稍微解決一些
第一步:定義一個Map
用來儲存表格懶加載每次展開時所點擊的當前行{tree,treeNode,resolve}
data(){
return{
maps: new Map(), // 先在你的data內(nèi)搞一個map用于存儲接下來必要的數(shù)據(jù)
}
}第二步:在load方法內(nèi)使用map
每次點擊展開load方法都會返回{tree,treeNode,resolve}, 定義好map后在每一次執(zhí)行l(wèi)oad方法調用接口成功返回數(shù)據(jù)后將load返回的參數(shù){tree,treeNode,resolve}儲存到map中去,用于后續(xù)操作中使用
load(tree, treeNode, resolve) {
if (treeNode) {
// 這是我的方法和接口不必照搬只需要將this.maps.set()這一句放到相應位置即可
selectBom({
code: tree.code,
ifMba: this.ifMba,
}).then((res) => {
if (res.code == 200) {
resolve(res.data);
this.maps.set(tree.code, { tree, treeNode, resolve });
// 上面這一句是將你每一次展開的節(jié)點存到你剛剛在data內(nèi)定義的map內(nèi),其他的不重要
// tree.code是唯一值
}
});
}
},第三步:查詢map中對應數(shù)據(jù)
已經(jīng)將每次展開load返回的{tree,treeNode,resolve}存儲到map中后,我們現(xiàn)在就需要取出來再傳給load方法了,調用refreshLoadTree方法時需要給它傳一個你所操作節(jié)點父節(jié)點ID,他會通過這個ID去map中檢索出相對應的數(shù)據(jù)然后再調用load方法傳給它以達到局部更新的目的
refreshLoadTree(pId) {
// 根據(jù)更改節(jié)點的父ID取出相應數(shù)據(jù)
const { tree, treeNode, resolve } = this.maps.get(pId);
this.$set(
// 不要忘記在你的table上寫ref
this.$refs.LoadTable.store.states.lazyTreeNodeMap,
pId,
[]
);
if (tree) {
// 將取出對應數(shù)據(jù)再傳給load方法
this.load(tree, treeNode, resolve);
}
},第四步:調用 refreshLoadTree方法
只需要在你修改或刪除等操作接口返回成功時調用并傳一個操作節(jié)點父ID即可實現(xiàn)局部數(shù)據(jù)更新
//最后只需要在你做修改刪除或者其他操作的地方調用即可 //括號內(nèi)傳操作節(jié)點的父節(jié)點(如果自己拿不到可以在接口成功時讓后端返回) this.refreshLoadTree(res.data.code);
這是基礎版本,因為本人項目原因會再次之上改動許多并未附上全部(僅作為記錄)
到此這篇關于vue+element tree懶加載更新數(shù)據(jù)的文章就介紹到這了,更多相關vue element tree懶加載內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue3項目typescript如何export引入(imported)的interface問題
這篇文章主要介紹了vue3項目typescript如何export引入(imported)的interface問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06
VsCode工具開發(fā)vue項目必裝插件清單(推薦!)
對于很多使用vscode編寫vue項目的新手同學來說,可能不知道使用什么插件,下面這篇文章主要給大家介紹了關于VsCode工具開發(fā)vue項目必裝插件的相關資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下2022-09-09

