elementui 后臺(tái)管理系統(tǒng)遇到的問題(二) 樹形控件 el-tree

elementui中樹形控件的使用

一、將后臺(tái)返回的數(shù)據(jù)填充到前端控件中登疗,需要注意的幾點(diǎn)問題

(1)排截、el-tree中需要綁定node-key='自定義的id名稱'
(2)、在配置data中defaultProps中的屬性時(shí)辐益,要按照與后端協(xié)商的字段名稱對(duì)稱
(3)断傲、重要的是要月后端協(xié)商返回字段內(nèi)容:

協(xié)商返回的數(shù)據(jù)格式(舉例):

children: Array(6) //與defaultProps中的children對(duì)應(yīng)
menuId: 1 //與node-key對(duì)應(yīng)
name: "運(yùn)維管理"  //與defauktProps中的label字段相對(duì)應(yīng);
parentId: 0 //父節(jié)點(diǎn)id
path: "/"

二智政、當(dāng)前端要將選中的菜單項(xiàng)傳入后端的時(shí)候认罩,現(xiàn)有的API中當(dāng)選中父菜單時(shí)候所有的子菜單會(huì)checked,但是當(dāng)該菜單下不是選中所有子菜單的時(shí)候女仰,這時(shí)候主菜單不會(huì)被checked猜年,而API中el-tree的getCheckedKeys()方法只會(huì)選中屬性為checked菜單的名為 node-key對(duì)應(yīng)的id的集合抡锈,這時(shí)候有三種方法

(1)疾忍、第一種方法:
1、找到項(xiàng)目中的\node_modules\element-ui\lib\element-ui.common.js文件床三;
2一罩、搜索文件中的TreeStore.prototype.getCheckedNodes方法中的;

if (child.checked && (!leafOnly || leafOnly && child.isLeaf)) {
          checkedNodes.push(child.data);
}

3撇簿、修改成

if ((child.checked || child.indeterminate) && (!leafOnly || leafOnly && child.isLeaf)) {
          checkedNodes.push(child.data);
 }

4聂渊、重啟項(xiàng)目

console.log(this.$refs.tree.getCheckedKeys()); //就可以拿到父節(jié)點(diǎn)的ID啦

(2)、第二種方法

methods: {
      getCheckedNodes() {
        var rad=''
        var ridsa = this.$refs.tree.getCheckedKeys().join(',')// 獲取當(dāng)前的選中的數(shù)據(jù)[數(shù)組] -id, 把數(shù)組轉(zhuǎn)換成字符串
        var ridsb = this.$refs.tree.getCheckedNodes()// 獲取當(dāng)前的選中的數(shù)據(jù){對(duì)象}
        ridsb.forEach(ids=>{//獲取選中的所有的父級(jí)id
          rad+=','+ids.pid
        })
        rad=rad.substr(1) // 刪除字符串前面的','
        var rids=rad+','+ridsa
        var arr=rids.split(',')//  把字符串轉(zhuǎn)換成數(shù)組
        arr=[...new Set(arr)]; // 數(shù)組去重
        rids=arr.join(',')// 把數(shù)組轉(zhuǎn)換成字符串
        console.log(rids)
      }
    }

(3)四瘫、第三種方法(推薦) 官方新出的獲取半選中狀態(tài)的方法

let parentArr = this.$refs.tree.getHalfCheckedKeys()   //獲取半選中狀態(tài)的id
let childArr = this.$refs.tree.getCheckedKeys()  //獲取全選中的id
this.addRoleForm.rolePower = parentArr.concat(childArr)   //拼接在一起

API解釋相關(guān)方法屬性

屬性說明

參數(shù) 說明 類型 可選值 默認(rèn)值
data 展示數(shù)據(jù) Array ---- ---
empty-text 內(nèi)容為空的時(shí)候展示的文本 String --- ---
node-key 每個(gè)樹節(jié)點(diǎn)用來作為唯一標(biāo)識(shí)的屬性汉嗽,整棵樹應(yīng)該是唯一的 String --- ---
Props 配置選項(xiàng)(見props) object --- ---
render-after-expand 是否在第一次展開某個(gè)樹節(jié)點(diǎn)后才渲染其子節(jié)點(diǎn) boolean --- true
load 加載子樹數(shù)據(jù)的方法,僅當(dāng)lazy屬性為true時(shí)生效 function(node,resolve) -- --
default-expand-all 是否默認(rèn)展開所有節(jié)點(diǎn) boolean --- ---
show-checkbox 節(jié)點(diǎn)是否可被選擇 boolean --- ---

Props

參數(shù) 說明 類型 可選值 默認(rèn)值
label 指定節(jié)點(diǎn)標(biāo)簽為節(jié)點(diǎn)對(duì)象的某個(gè)屬性值 String找蜜,function(data,node) -- --
children 指定子樹為節(jié)點(diǎn)對(duì)象的某個(gè)屬性值 String --- ---
disabled 指定節(jié)點(diǎn)選擇框是否禁用為節(jié)點(diǎn)對(duì)象的某個(gè)屬性值 boolean,function(data,node) -- --
isLeaf 指定節(jié)點(diǎn)是否為葉子節(jié)點(diǎn)饼暑,僅在指定了 lazy 屬性的情況下生效 boolean,function(data,node) -- ---

更多的方法 詳情

element-ui官網(wǎng)

整個(gè)項(xiàng)目的代碼結(jié)構(gòu)

<template>
<div>
    <el-tree :data="data2" show-checkbox node-key="menuId" ref="tree" highlight-current :props="defaultProps" @check='slesCheck'>
    </el-tree>
</div>
</template>

<script>
export default {
    data() {
        return {
            data2: [],
            defaultProps: {
                children: 'children',
                label: 'name'
            },
        };
    },
    methods: {
        getMenu() {
            this.$axios.get('menu/queryMenuList').then(res => {
                this.data2 = res.data
                console.log(res.data)
            })
        },
        slesCheck() {
           // this.checkedIds = this.$refs.tree.getCheckedKeys();
            // var rad = ''
            // var ridsa = this.$refs.tree.getCheckedKeys().join(',') // 獲取當(dāng)前的選中的數(shù)據(jù)[數(shù)組] -id, 把數(shù)組轉(zhuǎn)換成字符串
            // var ridsb = this.$refs.tree.getCheckedNodes() // 獲取當(dāng)前的選中的數(shù)據(jù){對(duì)象}
            // ridsb.forEach(ids => { //獲取選中的所有的父級(jí)id
            //     rad += ',' + ids.parentId
            // })
            // rad = rad.substr(1) // 刪除字符串前面的','
            // var rids = rad + ',' + ridsa
            // this.addRoleForm.rolePower = rids.split(',') //  把字符串轉(zhuǎn)換成數(shù)組
            // this.addRoleForm.rolePower = [...new Set(this.addRoleForm.rolePower)]; // 數(shù)組去重
            // // rids = arr.join(',') // 把數(shù)組轉(zhuǎn)換成字符串
            // console.log(this.addRoleForm.rolePower)
            let parentArr = this.$refs.tree.getHalfCheckedKeys()
            let childArr = this.$refs.tree.getCheckedKeys()
            this.addRoleForm.rolePower = parentArr.concat(childArr)
            console.log(parentArr)
            console.log(childArr)
            console.log(this.addRoleForm.rolePower)
        },
        getMeunList() {
            // this.$axios.get('menu/queryMenuIdList?roleId=1').then(res=>
            // this.$refs.tree.setCheckedKeys( this.checkedIds); //修改前要先獲取該el-tree的選中狀態(tài)
            //     console.log(res)
            // })
        }
    },

    created() {
        this.getMenu()
        // this.getMeunList()
    }
}
</script>
<style>
.el-tree {
    margin-top: 60px;
    width: 200px;
}
</style>

遺留的問題!O醋觥9选!后臺(tái)返回的數(shù)組中既有父級(jí)菜單id又有子菜單id诚纸,但子菜單并不完整的情況下撰筷,運(yùn)用setCheckedKey()方法會(huì)將該父級(jí)菜單下的所有子菜單選中,有一個(gè)屬性check-strictly(在顯示復(fù)選框的情況下畦徘,是否嚴(yán)格的遵循父子不互相關(guān)聯(lián)的做法毕籽,默認(rèn)為 false)但是設(shè)置后當(dāng)子菜單數(shù)量很多的情況下抬闯,體驗(yàn)很不好,求教各路大神解惑

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末影钉,一起剝皮案震驚了整個(gè)濱河市画髓,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌平委,老刑警劉巖奈虾,帶你破解...
    沈念sama閱讀 218,941評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異廉赔,居然都是意外死亡肉微,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門蜡塌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來碉纳,“玉大人,你說我怎么就攤上這事馏艾±筒埽” “怎么了?”我有些...
    開封第一講書人閱讀 165,345評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵琅摩,是天一觀的道長铁孵。 經(jīng)常有香客問我,道長房资,這世上最難降的妖魔是什么蜕劝? 我笑而不...
    開封第一講書人閱讀 58,851評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮轰异,結(jié)果婚禮上岖沛,老公的妹妹穿的比我還像新娘。我一直安慰自己搭独,他們只是感情好婴削,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著牙肝,像睡著了一般唉俗。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上惊奇,一...
    開封第一講書人閱讀 51,688評(píng)論 1 305
  • 那天互躬,我揣著相機(jī)與錄音,去河邊找鬼颂郎。 笑死吼渡,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的乓序。 我是一名探鬼主播寺酪,決...
    沈念sama閱讀 40,414評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼坎背,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了寄雀?” 一聲冷哼從身側(cè)響起得滤,我...
    開封第一講書人閱讀 39,319評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎盒犹,沒想到半個(gè)月后懂更,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡急膀,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年沮协,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片卓嫂。...
    茶點(diǎn)故事閱讀 40,096評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡慷暂,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出晨雳,到底是詐尸還是另有隱情行瑞,我是刑警寧澤,帶...
    沈念sama閱讀 35,789評(píng)論 5 346
  • 正文 年R本政府宣布餐禁,位于F島的核電站血久,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏坠宴。R本人自食惡果不足惜洋魂,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評(píng)論 3 331
  • 文/蒙蒙 一绷旗、第九天 我趴在偏房一處隱蔽的房頂上張望喜鼓。 院中可真熱鬧,春花似錦衔肢、人聲如沸庄岖。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽隅忿。三九已至,卻和暖如春邦尊,著一層夾襖步出監(jiān)牢的瞬間背桐,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評(píng)論 1 271
  • 我被黑心中介騙來泰國打工蝉揍, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留链峭,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,308評(píng)論 3 372
  • 正文 我出身青樓又沾,卻偏偏與公主長得像弊仪,于是被迫代替她去往敵國和親熙卡。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評(píng)論 2 355