首先看效果图 data:image/s3,"s3://crabby-images/c3e48/c3e48a7e9aeb077f06597a4c7843127364df3526" alt="在这里插入图片描述" 通过已选人员的删除实现表格勾选的取消。
关键代码是使用element里面的toggleRowSelection这个关键方法 data:image/s3,"s3://crabby-images/79de7/79de798f6b2d5be8eefa1c5f7046ab524aee7239" alt="请添加图片描述" 保留已选的数据使用的是reserve-selection 要配合row-key一起使用 data:image/s3,"s3://crabby-images/614f8/614f8c6464fca808d3daddecdeb7b78ab66d8425" alt="请添加图片描述" data:image/s3,"s3://crabby-images/efa46/efa461a81d15d784b16696dba232326bb08ed814" alt="请添加图片描述"
上代码 表格数据
<el-table
ref="userTable"
size="small"
:data="tableData"
row-key="id"
style="width: 100%; height: 285px"
@selection-change="handleSelectionChange"
>
<el-table-column type="selection" reserve-selection width="55">
</el-table-column>
<template v-for="(item, index) in tableColumn">
<el-table-column
:prop="item.prop"
:label="item.label"
:width="item.width"
:key="index"
>
</el-table-column>
</template>
</el-table>
js部分关键代码
watch: {
selectArr(val) {
val.forEach((row) => {
this.$refs.userTable.toggleRowSelection(row, true);
});
const arr = [];
const newArr = [];
for (let j = 0; j < val.length; j++) {
arr[val[j].id] = true;
}
for (let i = 0; i < this.selectNewArr.length; i++) {
if (!arr[this.selectNewArr[i].id]) {
newArr.push(this.selectNewArr[i]);
}
}
newArr.forEach((row) => {
this.$refs.userTable.toggleRowSelection(row, false);
});
},
}
data:image/s3,"s3://crabby-images/9d60a/9d60a6abf1007a661c9befe2dd4290efa9d8741b" alt="请添加图片描述"
|