Element-ui tree組件自定義節(jié)點(diǎn)使用方法代碼詳解
工作上使用到element-ui tree 組件,主要功能是要實(shí)現(xiàn)節(jié)點(diǎn)拖拽和置頂,通過自定義內(nèi)容方法(render-content)渲染樹代碼如下~
<template>
<div class="sortDiv">
<el-tree :data="sortData" draggable node-key="id" ref="sortTree" default-expand-all :expand-on-click-node="false" :render-content="renderContent" :allow-drop="allowDrop">
</el-tree>
<el-button @click="getData">獲取數(shù)據(jù)</el-button>
</div>
</template>
<script>
export default {
name: 'Sort',
data() {
return {
sortData: [
{
id: 1,
label: '一級(jí) 1',
checkItem: true,
children: [
{
id: 4,
label: '二級(jí) 1-1',
checkItem: false
},
{
id: 9,
label: '二級(jí) 1-2',
checkItem: false
},
{
id: 10,
label: '二級(jí) 1-3',
checkItem: false
}
]
},
{
id: 2,
label: '一級(jí) 2',
checkItem: true,
children: [
{
id: 5,
label: '二級(jí) 2-1',
checkItem: true
},
{
id: 6,
label: '二級(jí) 2-2',
checkItem: true
}
]
},
{
id: 3,
label: '一級(jí) 3',
checkItem: true,
children: [
{
id: 7,
label: '二級(jí) 3-1',
checkItem: true
},
{
id: 8,
label: '二級(jí) 3-2',
checkItem: false
}
]
}
]
};
},
methods: {
// 是否允許拖拽
allowDrop (draggingNode, dropNode, type) {
if (draggingNode.parent === dropNode.parent) {
return type !== 'inner'
}
else return false
},
//獲取數(shù)據(jù)
getData () {
let result = this.$refs['sortTree'].data;
let sortRulesMaps = [];
result.forEach((element, index) => {
let item = null;
if (element.checkItem) {
if (element.children && element.children.length > 0) {
item = {
orderIndex: index,
sortField: element.label,
rule: ['OTHERS']
};
element.children.forEach(i => {
if (i.checkItem) {
item.rule.push(i.label);
}
});
item.rule = item.rule.join('_');
}
}
item && sortRulesMaps.push(item);
});
},
//同級(jí)置頂功能
toTop(node, data) {
let c = Object.assign({}, data);
if (node.parent.level === 0) {
this.sortData.unshift(c)
} else {
node.parent.data.children.unshift(c);
}
this.$refs['sortTree'].remove(data.id);
},
changeNode(r, node, data) {
data.checkItem = r;
},
//自定義內(nèi)容
renderContent(h, { node, data }) {
return (
<span class="custom-tree-node">
<span>{data.label}</span>
<span>
<el-checkbox
v-model={data.checkItem}
checked={data.checkItem}
on-change={r => this.changeNode(r, node, data)}
/>
<el-button
size="mini"
type="text"
on-click={() => this.toTop(node, data)}
style="color:#707375;margin-left:10px"
>
<i class="fa fa-arrow-up">置頂</i>
</el-button>
</span>
</span>
);
}
}
};
</script>
<style lang="scss">
.sortDiv {
.el-icon-caret-right:before {
content: '\E604';
}
}
.custom-tree-node {
flex: 1;
display: flex;
align-items: center;
justify-content: space-between;
font-size: 14px;
padding-right: 8px;
}
</style>
補(bǔ)充:下面看下使用element的自定義tree組件的實(shí)例代碼
在使用elemnet-ui時(shí),需要自定義tree的一些元素,采用 :render-content屬性來進(jìn)行渲染這些元素,但是官網(wǎng)給的例子有一點(diǎn)小坑,
renderContent:function(createElement, { node, data, store }) {
var self = this;
return createElement('span', [
createElement('span', node.label),
createElement('span', {attrs:{
style:"float: right; margin-right: 200px"
}},[
createElement('el-button',{attrs:{
size:"mini"
},on:{
click:function() {
console.info("點(diǎn)擊了節(jié)點(diǎn)" + data.id + "的添加按鈕");
store.append({ id: self.baseId++, label: 'testtest', children: [] }, data);
}
}},"添加"),
createElement('el-button',{attrs:{
size:"mini"
},on:{
click:function() {
console.info("點(diǎn)擊了節(jié)點(diǎn)" + data.id + "的刪除按鈕");
store.remove(data);
}
}},"刪除"),
]),
]);
}
總結(jié)
以上所述是小編給大家介紹的Element-ui tree組件自定義節(jié)點(diǎn)使用方法代碼詳解,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Vue實(shí)現(xiàn)渲染數(shù)據(jù)后控制滾動(dòng)條位置(推薦)
這篇文章主要介紹了Vue實(shí)現(xiàn)渲染數(shù)據(jù)后控制滾動(dòng)條位置,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12
vue實(shí)現(xiàn)a標(biāo)簽點(diǎn)擊高亮方法
下面小編就為大家分享一篇vue實(shí)現(xiàn)a標(biāo)簽點(diǎn)擊高亮方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-03-03
vue用Object.defineProperty手寫一個(gè)簡單的雙向綁定的示例
這篇文章主要介紹了用Object.defineProperty手寫一個(gè)簡單的雙向綁定的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-07-07
vue項(xiàng)目中使用ts(typescript)入門教程
最近項(xiàng)目需要將原vue項(xiàng)目結(jié)合ts的使用進(jìn)行改造,本文從安裝到vue組件編寫進(jìn)行了說明,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11

