多选el-tree回显时只选中了父级下面其中一个子菜单,但是导致这个父级下面子菜单全选

这篇主要是接上篇的遗留问题


在这里插入图片描述
在你将[2,3]这个数组提交给后端,那必然牵扯到回显的问题,回显的时候,使用了:

this.$nextTick(() => {
    var checkedId = res.permissionIds   // 后端返回res.permissionIds = [2,3]
    this.$refs.menuTree.setCheckedKeys(checkedId)    // 设置回显
})

然后你就发现了,由于后端返回的数组里有父级id,所以根据el-tree的是否严格的遵循父子不互相关联(默认false)的原则,它回显成了这样,子级整个全选:
在这里插入图片描述
然后根据他这个是否严格遵循父子级相互不关联的原则:check-strictly来写一下,默认是相互关联的,那么在回显的时候将它设置为不关联,回显成功后再设置为关联:

this.checkStr = true   // 在回显的时候,设置不关联,那[2,3]只会选中父级和这个符合的子菜单
this.$nextTick(() => {
    var checkedId = res.permissionIds   // 后端返回res.permissionIds = [2,3]
    this.$refs.menuTree.setCheckedKeys(checkedId)    // 设置回显
    this.checkStr = false    // 回显完成后,再次设置互相关联
})

到这里就解决了,然后你就发现这有一个小问题,就是父级菜单这样回显他的checkbox不是半选中状态,而是一个对勾,不影响功能,而且在你点击其他菜单后也能恢复过来,就是回显后看着不美,有解决办法请赐教~

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值