怎样在关闭标签的同时取消表格选中状态?

当多选框选中时对应的姓名以标签的形式出现在下面已选人员中(已实现),
怎样在关闭标签的时候同时取消表格选中状态
image.png
当点了标签的叉之后,标签关闭了,但是表格还是选中状态
image.png

//标签数组
const dynamicTags:any = ref([])
//关闭标签
const handleClose = (tag: string) => {
    dynamicTags.value.splice(dynamicTags.value.indexOf(tag), 1)
}

const tableRef = ref<InstanceType<typeof ElTable>>()
//获取选中的行
const change = () => {
    const rows: any[] = tableRef.value?.getSelectionRows()
    for(let item of rows){
        dynamicTags.value.push(item.nickName)
    }
    console.log(dynamicTags.value);
}
阅读 1.9k
3 个回答

你关闭标签的事件handleClose中加一下取消表格选中状态的逻辑,根据标签名获取下是哪一行数据,然后调用toggleRowSelection取消选中
image.png

你这代码只有获取选中行没有删除行啊

const handleClose = (tag: string) => {
    dynamicTags.value.splice(dynamicTags.value.indexOf(tag), 1)
    // console.log(tag);
    const rows: any[] = tableRef.value?.getSelectionRows()
    for (let i of rows) {
        if (tag == i.nickName) {
            tableRef.value?.toggleRowSelection(i,false)
        }
    }
}
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题