ElementUI 的 Tree 組件的基本使用實(shí)戰(zhàn)教程
起因
事情是這樣的,項(xiàng)目最近有個(gè)需求。服務(wù)器有個(gè)圖片空間,說白了就是個(gè)文件夾。文件夾的結(jié)構(gòu)大家都知道,一層一層的。然后需要在前端以樹形展示。
具體的需求如下
- 可以新建子目錄,但是只能新建二級,三級的時(shí)候新建按鈕置灰。
- 在頁面上展示父級目錄名稱和當(dāng)前所在路徑,用 ‘/’ 分隔。
- 根目錄固定為 圖片空間 。
- 頁面首次打開的時(shí)候,請求接口,只返回一級目錄,默認(rèn)展示所有一級目錄。
- 用戶點(diǎn)擊一級目錄,根據(jù)所點(diǎn)擊的一級目錄對應(yīng)的 id 請求接口返回二級目錄,以此類推。
我當(dāng)時(shí)看到這個(gè)需求的時(shí)候,心里想,這玩意我在 ElementUI
的官網(wǎng)見過,好說。結(jié)果當(dāng)我去開發(fā)的時(shí)候,發(fā)現(xiàn)還是挺復(fù)雜的,于是我就花了點(diǎn)時(shí)間了研究一下,以防下次用的時(shí)候忘了。
處理
先把 elementUI
的官方例子拷下來。然后又隨便添加了點(diǎn)內(nèi)容。
<template> <div> <el-input v-model="input" style="width:200px" placeholder="請輸入內(nèi)容"></el-input> <el-button type="primary">添加節(jié)點(diǎn)</el-button> <span>當(dāng)前目錄:</span> <span>當(dāng)前目錄的父級目錄:</span> <el-tree :data="data" :props="defaultProps" accordion @node-click="handleNodeClick"></el-tree> </div> </template> <script> export default { data() { return { input: '', data: [{ label: '圖片空間', children: [{ label: '蔬菜', children: [{ label: '菠菜', }, { label: '生菜', }, ], }, { label: '水果', children: [{ label: '香蕉', }], }, { label: '美女', children: [{ label: '秦嵐', }], }], }], defaultProps: { children: 'children', label: 'label', }, }; }, methods: { handleNodeClick(data) { console.log(data); }, }, }; </script>
現(xiàn)在的界面是這樣的。
需求一
先從最簡單的開始吧。在任意目錄下添加分類(子節(jié)點(diǎn))。
然后我們?nèi)タ次臋n怎么說。嗯,就是它了。
接收兩個(gè)參數(shù) (data, parentNode)
- 要追加的子節(jié)點(diǎn)的
data
- 子節(jié)點(diǎn)的
parent
的data
、key
或者node
第一個(gè)參數(shù) data
在當(dāng)前的例子中就是一個(gè)名字而已。第二個(gè)參數(shù)要傳的東西怎么獲取呢?
要給目錄添加子節(jié)點(diǎn),肯定要先點(diǎn)一下這個(gè)目錄,那我們看看點(diǎn)擊事件都能給我們返回什么東西。
可以看到第二個(gè)回調(diào)參數(shù)就是 節(jié)點(diǎn)對應(yīng)的node
, 這不就有了么!那就來試一下。
修改代碼如下,我們點(diǎn)擊節(jié)點(diǎn)的時(shí)候,把點(diǎn)擊事件回調(diào)的參數(shù) node
先存在變量 nowClickNode
中,然后我們調(diào)用 append
方法的時(shí)候,再把 nowClickNode
給傳過去。
// 為了節(jié)省篇幅,省略template中的代碼,文末會貼出整體代碼 methods: { // 點(diǎn)擊節(jié)點(diǎn) handleNodeClick(nodes, node, self) { this.nowClickNode = node; }, // 添加節(jié)點(diǎn) addSort() { const data = { label: '草莓', }; this.$refs.tree.append(data, this.nowClickNode); }, },
成功啦!
那么怎么實(shí)現(xiàn)只可以建二級目錄,三級的時(shí)候置灰呢,我們點(diǎn)擊的時(shí)候不是保存了一個(gè)變量 nowClickNode
么。
這個(gè)變量里面有個(gè) level
屬性,代表的就是層級。我通過計(jì)算屬性來完成這個(gè)需求。
//template <el-button type="primary" :disabled='isDisabled' @click='addSort'>添加節(jié)點(diǎn)</el-button> //js computed: { // 是否可以新建分類 isDisabled() { if (this.nowClickNode.level > 2) { return true; } return false; }, },
可以看到我們點(diǎn)擊到三級的時(shí)候按鈕就禁用了。
需求二
接下來我們實(shí)現(xiàn)第二個(gè)需求,顯示當(dāng)前所在路徑和父級目錄。這個(gè)示例圖看上面那張就可以了,已經(jīng)實(shí)現(xiàn)了。
// 點(diǎn)擊節(jié)點(diǎn)的時(shí)候觸發(fā)事件 handleNodeClick(nodes, node, self) { this.nowClickNode = node; this.nowPathArr = []; // 如果不是根節(jié)點(diǎn) if (node.parent.parent) { this.faterName = node.parent.data.label; // 遞歸找路徑 this.findParentName(node); // 拼接路徑 this.nowPath = `圖片空間 / ${this.nowPathArr.join(' / ')}`; } else { // 如果是根節(jié)點(diǎn) 直接賦值 this.nowPath = '圖片空間'; this.faterName = '- -'; } }, // 查找父節(jié)點(diǎn)的分類名稱 findParentName(node) { if (node.parent.parent) { this.nowPathArr.unshift(node.data.label); this.findParentName(node.parent); } },
這個(gè)不知道怎么回事,我的根目錄也有 parent
屬性,所以只能再向上找一層,通過 parent.parent
存不存在來判斷是不是根節(jié)點(diǎn)。
我是在點(diǎn)擊的時(shí)候,遞歸查找點(diǎn)擊節(jié)點(diǎn)的父元素,然后把所有祖代元素放在數(shù)組里,最后進(jìn)行拼接。
需求三,四,五
剩下的三個(gè)需求放在一起講,這個(gè)地方我練習(xí)的時(shí)候用的項(xiàng)目真實(shí)數(shù)據(jù),不方便演示,代碼也是經(jīng)過脫敏處理的。重要的是知道怎么用就可以了。
//template <el-tree :data="treeData" //數(shù)據(jù)源 :props="defaultProps" //配置項(xiàng) accordion //每次打開一個(gè)節(jié)點(diǎn) 手風(fēng)琴模式 ref="tree" //用來獲取dom lazy //節(jié)點(diǎn)懶加載 :highlight-current='true' //高亮當(dāng)前節(jié)點(diǎn) :load='treeLoad' //懶加載時(shí)調(diào)用的方法 node-key="cateId" //唯一標(biāo)識 :default-expanded-keys='defaultOpen' //默認(rèn)打開的節(jié)點(diǎn)數(shù)組 :expand-on-click-node='true' //是否在點(diǎn)擊節(jié)點(diǎn)的時(shí)候展開或者收縮節(jié)點(diǎn), 默認(rèn)值為 true,如果為 false,則只有點(diǎn)箭頭圖標(biāo)的時(shí)候才會展開或者收縮節(jié)點(diǎn)。 @node-click="handleNodeClick" //點(diǎn)擊節(jié)點(diǎn)的回調(diào)函數(shù) > </el-tree> //js // 加載樹形結(jié)構(gòu) 就是上面懶加載綁定的函數(shù) treeLoad(node, resolve) { // 判斷節(jié)點(diǎn)等級 if (node.level == 0) { // 如果是根節(jié)點(diǎn),添加一個(gè)固定的圖片空間節(jié)點(diǎn) 這是實(shí)現(xiàn)需求三 resolve([{ cateName: '圖片空間', cateId: '0', children: [], }]); } // 不是根節(jié)點(diǎn),調(diào)取接口加載列表 這里實(shí)現(xiàn)需求四,五的樹結(jié)構(gòu)懶加載,點(diǎn)完一級請求一級的數(shù)據(jù) if (node.level >= 1) { this.getCategoryListNew(node, resolve); // 防止子節(jié)點(diǎn)為空時(shí)一直出現(xiàn)加載動畫 return resolve([]); } }, // 獲取樹形結(jié)構(gòu) 上面掉用的請求接口 data處理完之后要調(diào)用resolve方法 getCategoryListNew(node, resolve) { Service.getCategoryListNew({ parentId: node.data.cateId }).then(({ data }) => { resolve(data); }).catch((e) => { console.log(e); }); },
其他知識點(diǎn)
另外記錄幾個(gè)知識點(diǎn)
默認(rèn)展開節(jié)點(diǎn)
默認(rèn)展開使用的是 :default-expanded-keys='defaultOpen'
屬性, defaultOpen
里面存放的是 node-key
的數(shù)組。
橫縱向滾動條
首先要給 tree
組件的外層添加 寬高
,以及 overflow
屬性。然后要修改 el-tree
的屬性。
.tree-box{ width: 200px; height: calc(100% - 30px); overflow:auto; } .el-tree { display: inline-block; min-width: 100%; }
刷新某一個(gè)節(jié)點(diǎn)
// 通過節(jié)點(diǎn)id找到對應(yīng)樹節(jié)點(diǎn)對象 const node = this.$refs.tree.getNode(this.nodeId); // 把loaded手動置為false,也就是告訴tree這個(gè)節(jié)點(diǎn)沒有加載過 node.loaded = false; // 主動調(diào)用展開節(jié)點(diǎn)方法,重新查詢該節(jié)點(diǎn)下的所有子節(jié)點(diǎn) node.expand();
模擬點(diǎn)擊一級目錄中第一個(gè)節(jié)點(diǎn)
// 選取dom const root = document.querySelector('.el-tree-node__children'); // 找到目標(biāo)節(jié)點(diǎn) const firstNode = root.firstChild; // 模擬點(diǎn)擊 firstNode.click();
到此這篇關(guān)于ElementUI 的 Tree 組件的基本使用實(shí)戰(zhàn)教程的文章就介紹到這了,更多相關(guān)ElementUI 的 Tree 組件使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript實(shí)現(xiàn)移動小精靈的案例代碼
這篇文章主要介紹了JavaScript實(shí)現(xiàn)移動小精靈的案例代碼,本文分步驟給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12JavaScript鏈?zhǔn)秸{(diào)用實(shí)例淺析
這篇文章主要介紹了JavaScript鏈?zhǔn)秸{(diào)用,結(jié)合實(shí)例形式分析了javascript鏈?zhǔn)秸{(diào)用的相關(guān)原理、實(shí)現(xiàn)方法及操作注意事項(xiàng),需要的朋友可以參考下2018-12-12js判斷IE6/IE7/FF的代碼[XMLHttpRequest]
js下通過XMLHttpRequest判斷IE6/IE7/FF的代碼,需要的朋友可以參考下。2011-02-02使用JS在瀏覽器中判斷當(dāng)前網(wǎng)絡(luò)連接狀態(tài)的幾種方法
本篇文章主要介紹了使用JS在瀏覽器中判斷當(dāng)前網(wǎng)絡(luò)狀態(tài)的幾種方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-05-05javascript 實(shí)現(xiàn)鍵盤上下左右功能的小例子
這篇文章介紹了javascript 實(shí)現(xiàn)鍵盤上下左右功能的小例子,有需要的朋友可以參考一下2013-09-09