在使用Element UI时,可以通过结合el-select
和el-tree
组件实现下拉树形结构的选择器。以下是一个简单的实现示例:
<template>
<el-row>
<el-col :span="12">
<el-select
v-model="selectedValue"
placeholder="请选择"
@change="handleChange"
>
<el-option
v-for="item in options"
:key="item.value"
:label="item.label"
:value="item.value"
></el-option>
</el-select>
</el-col>
<el-col :span="12">
<el-tree
:data="treeData"
:props="defaultProps"
@node-click="handleNodeClick"
></el-tree>
</el-col>
</el-row>
</template>
<script>
export default {
data() {
return {
selectedValue: null,
options: [],
treeData: [
{
id: 1,
label: '一级 1',
children: [
{
id: 4,
label: '二级 1-1',
},
],
},
// ... 更多树节点数据
],
defaultProps: {
children: 'children',
label: 'label',
},
};
},
methods: {
handleChange(value) {
// 当选择项变更时的处理逻辑
},
handleNodeClick(data, node, component) {
// 当树节点被点击时的处理逻辑
this.selectedValue = data.id;
this.options = [{ label: data.label, value: data.id }];
},
},
};
</script>
在这个示例中,我们有一个el-select
组件用于展示选中的项,和一个el-tree
组件作为下拉菜单。当用户从下拉菜单中选择一个节点时,该节点的信息会被赋值给el-select
并隐藏下拉菜单。这个简单的实现提供了一个基础框架,您可以根据实际需求进一步扩展和定制。