element el-tree 选择状态回显

在使用elementUI的el-tree组件时,如果要设置默认选中的节点,通过setCheckedKeys方法设置时,发现只要包含父级id,所有子级都会被选中。实际上,需求是只选中部分子级和父级呈现半选中状态。通过过滤出子节点id并设置,可以实现合理的选择状态。同时提供了getCheckedNodes方法来获取选中和半选中的节点key。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:element UI el-tree 选择状态回显时,需要默认选中数据,这时调用this.$refs.tree.setCheckedKeys(array),发现array选中数据里只要包含父级id,那么它下面的所有子级都会被选中,但实际上我们并不没有选中所有子级,而是只选中其中一个或者两个,以及父级呈现半选中状态,这才是我们要的效果。

代码如下:

// 初始化菜单数据
async onLoad() {
    this.loading = true
    const response = await getList(this.paramsMenu)
    const { data } = response
    // 转为树形数据结构
    this.treeData = this.filter(data)
    // 找出所有父节点id
    const parentIds = this.treeData.map(item => item.id)
    // 从获取的已选择的数据中过滤掉父节点id,从而得到所有子节点id
    const childrenIds = this.defaultChecked.filter(id => !parentIds.includes(id))
    // 选中子节点,这时候父节点的选中状态就会成为合理的选择状态,即: 选中所有子节点-父节点呈现选中状态  不选中所有子节点-父节点会呈现半选中状态
    this.$refs.tree.setCheckedKeys(childrenIds)
    this.loading = false
},
// 处理选中数据
getCheckedNodes() {
    // 获取所有状态的父节点key
    let parentList = this.$refs.tree.getHalfCheckedKeys()
    // 获取选中状态的子节点key
    let chirenldList = this.$refs.tree.getCheckedKeys()
    // 合并返回: 保存时提交的数据
    return [...parentList,...chirenldList]
},

 效果图:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值