vue3根据数据取消el-table选中状态获取到最新数据

原始数据:

javascript 复制代码
//el-table点击复选框事件
function getSelected(selection, row){
  //判断是否是已选过数据 ==0为没有选,>0有选过
  if(initial.value>0 ){
    let isCheck = false //是否取消 true=取消 false=不取消
    //循环判断已选的数据是否包含当前点击获取到的数据
    feeCodeData.value.forEach(imgItem => {
      //包含当前数据,表示取消选中的操作,需要从已选数据中删除
      if (imgItem.id === row.id) {
        // 先findIndex拿到index,否则直接否则直接splice(imgItem,1)是会删除失败的!
        feeCodeData.value.splice(feeCodeData.value.findIndex((item) => item.id === row.id), 1)
        isCheck = true
      }
    })
    //已选数据中不包含当前数据,表示选中的操作,需要添加到已选的数据中
    if(!isCheck){
      feeCodeData.value.push(row)
    }
  }
  //没有已选数据,直接将选中的数据添加到数组中
  else{
    feeCodeData.value.push(row)
  }
}

结果显示:

相关推荐
叫回忆4 分钟前
elpis的动态组件拓展
javascript
yuki_uix6 分钟前
从扁平到层级:树形数据转换的工程化实践与设计哲学
前端·javascript
米丘7 分钟前
vue-router 5.x 关于 RouterLink 实现原理
前端·javascript·vue.js
whisper12 分钟前
前端安全护航者:三分钟带你了解 jsencrypt
前端·javascript
枫林之恋14 分钟前
面试官最爱问的图片懒加载,我总结了这3种实现方式
javascript
远山枫谷16 分钟前
🎉告别 Vuex!Vue3 状态管理利器 Pinia 核心概念与实战指南
前端·vue.js
光影少年19 分钟前
Vue组件通信方式?
前端·vue.js·掘金·金石计划
SuniaWang21 分钟前
Vue 项目 Docker 多阶段构建部署指南(阿里云)
vue.js·阿里云·docker
庄小焱26 分钟前
Vue——Vue基础语法(1)
前端·javascript·vue.js·前端框架