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)
樹(shù)組件
<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-11vue單頁(yè)應(yīng)用中如何使用jquery的方法示例
最近在工作中遇到的一個(gè)需求,需要在vue-cli建立的應(yīng)用中引入jquery的方式,通過(guò)查找相關(guān)的資料最終解決了,所以這篇文章主要給大家介紹了關(guān)于在vue單頁(yè)應(yīng)用中如何使用jquery的方法示例,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-07-07Vue中虛擬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-05Vue實(shí)現(xiàn)簡(jiǎn)易購(gòu)物車(chē)案例
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)簡(jiǎn)易購(gòu)物車(chē)案例,文中示例代碼介紹的非常詳細(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-05VueJs中的shallowRef與shallowReactive函數(shù)使用比較
這篇文章主要為大家介紹了VueJs中的shallowRef與shallowReactive函數(shù)的使用比較解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04