(1)、el-tree中須要綁定node-key='自定義的id名稱'
(2)、在配置data中defaultProps中的屬性時,要按照與後端協商的字段名稱對稱
(3)、重要的是要月後端協商返回字段內容:前端
children: Array(6) //與defaultProps中的children對應 menuId: 1 //與node-key對應 name: "運維管理" //與defauktProps中的label字段相對應; parentId: 0 //父節點id path: "/"
(1)、第一種方法:
一、找到項目中的\node_modules\element-ui\lib\element-ui.common.js文件;
二、搜索文件中的TreeStore.prototype.getCheckedNodes方法中的;node
if (child.checked && (!leafOnly || leafOnly && child.isLeaf)) { checkedNodes.push(child.data); }
三、修改爲ios
if ((child.checked || child.indeterminate) && (!leafOnly || leafOnly && child.isLeaf)) { checkedNodes.push(child.data); }
四、重啓項目element-ui
console.log(this.$refs.tree.getCheckedKeys()); //就能夠拿到父節點的ID啦
(2)、第二種方法axios
methods: { getCheckedNodes() { var rad='' var ridsa = this.$refs.tree.getCheckedKeys().join(',')// 獲取當前的選中的數據[數組] -id, 把數組轉換成字符串 var ridsb = this.$refs.tree.getCheckedNodes()// 獲取當前的選中的數據{對象} ridsb.forEach(ids=>{//獲取選中的全部的父級id rad+=','+ids.pid }) rad=rad.substr(1) // 刪除字符串前面的',' var rids=rad+','+ridsa var arr=rids.split(',')// 把字符串轉換成數組 arr=[...new Set(arr)]; // 數組去重 rids=arr.join(',')// 把數組轉換成字符串 console.log(rids) } }
(3)、第三種方法(推薦) 官方新出的獲取半選中狀態的方法後端
let parentArr = this.$refs.tree.getHalfCheckedKeys() //獲取半選中狀態的id let childArr = this.$refs.tree.getCheckedKeys() //獲取全選中的id this.addRoleForm.rolePower = parentArr.concat(childArr) //拼接在一塊兒
參數 | 說明 | 類型 | 可選值 | 默認值 |
---|---|---|---|---|
data | 展現數據 | Array | ---- | --- |
empty-text | 內容爲空的時候展現的文本 | String | --- | --- |
node-key | 每一個樹節點用來做爲惟一標識的屬性,整棵樹應該是惟一的 | String | --- | --- |
Props | 配置選項(見props) | object | --- | --- |
render-after-expand | 是否在第一次展開某個樹節點後才渲染其子節點 | boolean | --- | true |
load | 加載子樹數據的方法,僅當lazy屬性爲true時生效 | function(node,resolve) | -- | -- |
default-expand-all | 是否默認展開全部節點 | boolean | --- | --- |
show-checkbox | 節點是否可被選擇 | boolean | --- | --- |
accordion | 是否每次只打開一個同級樹節點展開 | boolean | --- | false |
indent | 相鄰級節點間的水平縮進,單位爲像素 | number | --- | 16 |
參數 | 說明 | 類型 | 可選值 | 默認值 |
---|---|---|---|---|
label | 指定節點標籤爲節點對象的某個屬性值 | String,function(data,node) | -- | -- |
children | 指定子樹爲節點對象的某個屬性值 | String | --- | --- |
disabled | 指定節點選擇框是否禁用爲節點對象的某個屬性值 | boolean,function(data,node) | -- | -- |
isLeaf | 指定節點是否爲葉子節點,僅在指定了 lazy 屬性的狀況下生效 | boolean,function(data,node) | -- | --- |
<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(',') // 獲取當前的選中的數據[數組] -id, 把數組轉換成字符串 // var ridsb = this.$refs.tree.getCheckedNodes() // 獲取當前的選中的數據{對象} // ridsb.forEach(ids => { //獲取選中的全部的父級id // rad += ',' + ids.parentId // }) // rad = rad.substr(1) // 刪除字符串前面的',' // var rids = rad + ',' + ridsa // this.addRoleForm.rolePower = rids.split(',') // 把字符串轉換成數組 // this.addRoleForm.rolePower = [...new Set(this.addRoleForm.rolePower)]; // 數組去重 // // rids = arr.join(',') // 把數組轉換成字符串 // 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的選中狀態 // console.log(res) // }) } }, created() { this.getMenu() // this.getMeunList() } } </script> <style> .el-tree { margin-top: 60px; width: 200px; } </style>