两个表格进行相互联动

一个表格进行数据展示的时候(A表格),我们进行数据选择时,需要另个表格(B表格)保存所选的数据,那两个表格就需要进行联动。比如: A表格复选框选择,则B表格就新增一条,当A复选框失去选择,则B表格则删除对应的数据。但是当A表分页或者重新加载的时候,则B中的数据,需要在A的表格中进行选中。

代码:

A表格:

复制代码
<el-table
v-loading="loading"
:data="targetTable"
style="width: 100%"
row-key="EXECUTION_STANDARD_ID"
border
stripe
ref="multipleTable"
height="100%"
:span-method="arraySpanMethod"
@select-all="selectALL"
@selection-change="handleSelectionChange">
</el-table>

当请求A表格的数据的时候,需要把B表中的数据进行选中操作

//注释:::::每次第一个表格的数据重新请求,则this.tableTemporaryList = [],一般写在请求第一个表格数据的位置。给第一个表格赋值时

复制代码
getTemplateExecutionStandard() {
	this.tableTemporaryList = []
 	if(this.activeTable.length >0) {
            this.targetTable.forEach(item=>{
              const index = this.activeTable.findIndex(x=>x.EXECUTION_STANDARD_ID == item.EXECUTION_STANDARD_ID)
              if(index != -1) {
                this.$nextTick(() => {
                  this.$refs.multipleTable.toggleRowSelection(item)
                })
              }
            })
	}
      },

当A表格复选框全选的时候,需要进行一个判断

复制代码
  //复选框
    selectALL(selection) {
      if(selection.length > 0) {
        selection.forEach(item=>{
          const index = this.activeTable.findIndex(res=>res.EXECUTION_STANDARD_ID == item.EXECUTION_STANDARD_ID)
          if(index == -1) {
            this.activeTable.push(item)
          }
        })
      }else {
        this.targetTable.forEach(item=>{
          if(item.NODE_ID) {
            const index = this.activeTable.findIndex(res=>res.EXECUTION_STANDARD_ID == item.EXECUTION_STANDARD_ID)
            if(index != -1) {
              this.activeTable.splice(index, 1)
            }
          }
        })
      }
    },

之后是复选框选择,因为selectChange方法每次给的都是选中的数据,当复选框删除某个数据的时候,我们则不知道了。这个时候就需要记录一下上次选中的数据,跟这次选择的数据,

复制代码
 //目标选择
    handleSelectionChange(val) {
      let maxLength = []
      let minLength = []
      let flag = ''
      if(val.length > this.tableTemporaryList.length) {
        maxLength = val;
        minLength = this.tableTemporaryList
        flag = 'add'
      }else {
        maxLength = this.tableTemporaryList
        minLength = val
        flag = 'delete'
      }
      const difference = this.getObjectArrayDifferenceById(maxLength, minLength)
      if(difference.length == 1) {
        const index = this.activeTable.findIndex(res=>res.EXECUTION_STANDARD_ID == difference[0].EXECUTION_STANDARD_ID)
        if(flag == 'add') {
          if(index == -1) {
            this.activeTable.push(difference[0])
          }
        }else {
          if(index != -1) {
            this.activeTable.splice(index, 1)
          }
        }
      }
      this.tableTemporaryList = val
    },
//对比两个数组
    getObjectArrayDifferenceById(array1, array2) {
      const ids2 = array2.map(obj => obj.EXECUTION_STANDARD_ID);
      return array1.filter(obj => !ids2.includes(obj.EXECUTION_STANDARD_ID));
    },

B表格: 这个表格就比较简单了。因为他只有删除操作。

复制代码
<el-table
              :data="activeTable"
              style="width: 100%"
              row-key="EXECUTION_STANDARD_ID"
              border
              stripe
              height="100%">
              <el-table-column
                label="操作"
                align="center"
                width="50">
                <template v-slot="scope">
                  <i class="el-icon-delete" @click="deleteTable(scope.row)"></i>
                </template>
              </el-table-column>
          </el-table>
    //删除检查项
    deleteTable(row) {
      for (let i=0; i<this.activeTable.length; i++) {
        if(this.activeTable[i].EXECUTION_STANDARD_ID == row.EXECUTION_STANDARD_ID) {
          this.activeTable.splice(i,1)
          const item = this.targetTable.find(item=> item.EXECUTION_STANDARD_ID == row.EXECUTION_STANDARD_ID)
          this.$refs.multipleTable.toggleRowSelection(item, false)
          return
        }
      }
    },
相关推荐
于慨1 天前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz1 天前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶1 天前
前端交互规范(Web 端)
前端
像我这样帅的人丶你还1 天前
别再让JS耽误你进步了。
css·vue.js
@yanyu6661 天前
07-引入element布局及spring boot完善后端
javascript·vue.js·spring boot
CHU7290351 天前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing1 天前
Page-agent MCP结构
前端·人工智能
王霸天1 天前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航1 天前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界1 天前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript