小魔女参考了bing和GPT部分内容调写:
在这种情况下,我们可以使用递归的方式来处理,将后台返回的三级数据转换成tree组件可以识别的格式,以便进行渲染。
具体处理方式如下:
// 定义函数,传入后台返回的三级数据
function handleData(data) {
// 定义一个新数组,用于存放处理完的数据
let newData = [];
// 遍历后台返回的三级数据
data.forEach(item => {
// 将数据转换成tree组件可以识别的格式
let obj = {
label: item.name,
bbiDivision: item.bbiDivision,
children: []
};
// 如果当前节点有子节点,则递归调用函数,处理子节点的数据
if (item.children && item.children.length > 0) {
obj.children = handleData(item.children);
}
// 将处理完的数据放入新数组中
newData.push(obj);
});
// 返回处理完的数据
return newData;
}
// 将处理完的数据传入tree组件,完成渲染
<Tree data={handleData(data)} />
回答不易,记得采纳呀。
tree组件有一个prop配置项,可以配置子节点数组的名称,直接将children改成bbiDivision就可以了
<el-tree
:data="data"
:props="defaultProps"
accordion
@node-click="handleNodeClick">
</el-tree>
<script>
export default {
data() {
return {
data: [{
label: '一级 1',
children: [{
label: '二级 1-1',
children: [{
label: '三级 1-1-1'
}]
}]
}, {
label: '一级 2',
children: [{
label: '二级 2-1',
children: [{
label: '三级 2-1-1'
}]
}, {
label: '二级 2-2',
children: [{
label: '三级 2-2-1'
}]
}]
}, {
label: '一级 3',
children: [{
label: '二级 3-1',
children: [{
label: '三级 3-1-1'
}]
}, {
label: '二级 3-2',
children: [{
label: '三级 3-2-1'
}]
}]
}],
defaultProps: {
children: 'bbiDivision',
label: 'label'
}
};
},
methods: {
handleNodeClick(data) {
console.log(data);
}
}
};
</script>