elementui 後臺管理系統遇到的問題(二) 樹形控件 el-tree

elementui中樹形控件的使用

1、將後臺返回的數據填充到前端控件中,須要注意的幾點問題

(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: "/"

2、當前端要將選中的菜單項傳入後端的時候,現有的API中當選中父菜單時候全部的子菜單會checked,可是當該菜單下不是選中全部子菜單的時候,這時候主菜單不會被checked,而API中el-tree的getCheckedKeys()方法只會選中屬性爲checked菜單的名爲 node-key對應的id的集合,這時候有三種方法

(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)   //拼接在一塊兒

API解釋相關方法屬性

屬性說明

參數 說明 類型 可選值 默認值
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

Props

參數 說明 類型 可選值 默認值
label 指定節點標籤爲節點對象的某個屬性值 String,function(data,node) -- --
children 指定子樹爲節點對象的某個屬性值 String --- ---
disabled 指定節點選擇框是否禁用爲節點對象的某個屬性值 boolean,function(data,node) -- --
isLeaf 指定節點是否爲葉子節點,僅在指定了 lazy 屬性的狀況下生效 boolean,function(data,node) -- ---

更多的方法 詳情http://element.eleme.io/#/zh-CN/component/tree

整個項目的代碼結構

<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>

遺留的問題!!!!

後臺返回的數組中既有父級菜單id又有子菜單id,但子菜單並不完整的狀況下,運用setCheckedKey()方法會將該父級菜單下的全部子菜單選中,有一個屬性check-strictly(在顯示覆選框的狀況下,是否嚴格的遵循父子不互相關聯的作法,默認爲 false)可是設置後當子菜單數量不少的狀況下,體驗很很差,求教各路大神解惑

相關文章
相關標籤/搜索