el-tree自动勾选的实现
在el-tree中,我们有时需要实现自动勾选功能,即当勾选某个节点时,根据某些条件自动勾选其他节点。本文将探讨如何实现此功能。
判断条件和预期结果
我们的目标是:当勾选某个节点时,判断该节点的标签是否符合特定模式(例如 x-n),如果是,则自动勾选该模式的另一个节点(x-0)。例如:
- 勾选 2-1,自动勾选 2-0。
- 勾选 3-1,自动勾选 3-0。
解决方案
可以在 check-change 事件中实现此逻辑。具体步骤如下:
- 分解勾选节点的标签,提取出类型(x)和序号(n)。
- 获取所有已勾选的节点。
-
检查是否满足以下条件:
- 当前勾选节点不是 x-0。
- 当前勾选的节点列表中没有 x-0。
- 如果条件满足,则自动勾选 x-0。
- 如果当前取消勾选的节点是 x-0,并且其他 x-n 节点被勾选,则重新勾选 x-0。
代码示例
<script setup lang="ts">
import { ref } from 'vue';
const treeRef = ref();
const data = ref([
{
label: 'root',
children: [
{ label: '2-0' },
{ label: '2-1' },
{ label: '2-2' },
{ label: '3-0' },
{ label: '3-1' },
{ label: '3-2' },
],
}
])
const handleCheckChange = (data, checked) => {
const [type, index] = data.label.split('-');
const checkedNodes = treeRef.value.getCheckedNodes();
// x-n被勾选,且x-0没被勾选,则勾选x-0
if (checked && index !== '0' && !checkedNodes.some(it => it.label === `${type}-0`)) {
treeRef.value.setChecked(`${type}-0`, true);
}
// x-0取消勾选,且有x-n被勾选,则重新勾选x-0
if (!checked && index === '0' && checkedNodes.some(it => it.label !== `${type}-0` && it.label.startsWith(`${type}-`))) {
treeRef.value.setChecked(`${type}-0`, true);
}
}
</script>
<template>
<el-tree
ref="treeRef"
:data="data"
show-checkbox
node-key="label"
default-expand-all
@check-change="handleCheckChange"
/>
</template>通过此解决方案,我们可以实现el-tree的自动勾选功能,满足预期的判断条件和结果。

