vue3 element-plus el-tree自定義圖標(biāo)方式
更新時(shí)間:2024年03月19日 08:36:56 作者:隨便叫個(gè)啥呢
這篇文章主要介紹了vue3 element-plus el-tree自定義圖標(biāo)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
vue3 element-plus el-tree自定義圖標(biāo)
樹組件

<template>
<div class="left-tree">
<el-tree
:data="treeData.data"
node-key="id"
:props="defaultProps"
:default-expanded-keys="[0]"
:default-checked-keys="[0]"
@node-click="nodeclick"
>
<template #default="scope">
<div class="custom-node">
<i
class="tree-icon"
:class="{
'el-icon-caret-right': !scope.node.expanded,
'el-icon-caret-bottom': scope.node.expanded,
'el-icon-wlj-yuandian': scope.data.is_leaf === 1
}"
:style="{ color: scope.data.is_leaf === 1 ? 'rgb(54,229,150)' : '#409eff' }"
/>
<span>{{ scope.node.label }}</span>
</div>
</template>
</el-tree>
</div>
</template>
<script lang="ts" setup>
import { onMounted, reactive } from "vue";
import { getDept } from "@/api/asset"
// 定義派發(fā)事件
const emit = defineEmits(['tree-node-click'])
const nodeclick = (data, node, component) => {
// console.log('子組件category的節(jié)點(diǎn)被點(diǎn)擊', data, node, component)
// 向父組件發(fā)送事件;
emit('tree-node-click', data, node, component)
}
let defaultProps = reactive({
children: 'children',
label: 'name',
})
let treeData: any = reactive({ data: [] })
async function getDeptTree() {
const data: any = await getDept({ POST_TYPE: 1 })
treeData.data = data.lists
console.log(treeData)
}
onMounted(async () => {
getDeptTree()
})
</script>
<style lang="scss" scoped>
//tree
.el-tree-node__content:hover {
background-color: rgb(255, 207, 131);
}
.el-tree-node:focus > .el-tree-node__content {
background-color: rgb(255, 207, 131);
}
.el-tree-node__label {
font-size: 1.5vh;
}
.el-tree-node__expand-icon {
color: transparent;
cursor: default;
}
//tree
.left-tree {
height: 73vh;
overflow: auto;
}
/*修改滾動(dòng)條樣式*/
.left-tree::-webkit-scrollbar {
width: 10px;
height: 10px;
/**/
}
.left-tree::-webkit-scrollbar-track {
background: rgb(104, 108, 143);
border-radius: 10px;
}
.left-tree::-webkit-scrollbar-thumb {
background: rgb(54, 229, 150);
border-radius: 10px;
}
// .left-tree::-webkit-scrollbar-thumb:hover{
// background: #333;
// }
// .left-tree::-webkit-scrollbar-corner{
// background: #179a16;
// }
.tree-icon {
margin-right: 1vh;
margin-left: -2vh;
}
.el-tree {
background: none;
color: #fff;
}
</style>
父組件
<dept-tree @tree-node-click="treenodeclick"/>
const treenodeclick = (data, node, component) => {
console.log(data);
}
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:
相關(guān)文章
簡(jiǎn)述vue路由打開(kāi)一個(gè)新的窗口的方法
這篇文章主要介紹了vue路由打開(kāi)一個(gè)新的窗口的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-11-11
vue單頁(yè)應(yīng)用中如何使用jquery的方法示例
最近在工作中遇到的一個(gè)需求,需要在vue-cli建立的應(yīng)用中引入jquery的方式,通過(guò)查找相關(guān)的資料最終解決了,所以這篇文章主要給大家介紹了關(guān)于在vue單頁(yè)應(yīng)用中如何使用jquery的方法示例,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-07-07
Vue中虛擬DOM的簡(jiǎn)單實(shí)現(xiàn)
Vue中的虛擬DOM是通過(guò)JavaScript對(duì)象來(lái)描述真實(shí)DOM結(jié)構(gòu)的一種方式,本文將介紹Vue中虛擬DOM的簡(jiǎn)單實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-05-05
Vue實(shí)現(xiàn)簡(jiǎn)易購(gòu)物車案例
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)簡(jiǎn)易購(gòu)物車案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06
詳解vue-cli3開(kāi)發(fā)Chrome插件實(shí)踐
這篇文章主要介紹了vue-cli3開(kāi)發(fā)Chrome插件實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
VueJs中的shallowRef與shallowReactive函數(shù)使用比較
這篇文章主要為大家介紹了VueJs中的shallowRef與shallowReactive函數(shù)的使用比較解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04

