vue3.0 el-table 行内点击图标 修改该条数据某个值

需求:点击el-table 中的单个状态旁边小图标可以进行修改该条数据的状态:原型图如下

点击编辑图标,可以进行如下图操作:

实现逻辑:

获取表格数据时,我们可以给其一个标志位,以此来展示改初始时为不可编辑状态,只有点击按钮才能显示选择框以及取消保存按钮,我们可以通过该条数据的 index row  的改变来达到我们的目的,修改该条数据。

代码如下:

 //初始时赋值标志位显示不可编辑状态
 res.data.rows.forEach(function(val, index) {
        val.index = index;
        val.edit = true;
   });


  <el-table-column
      property="状态"
      label="状态"
      min-width="180px"
      align="center"
    >
      <template #default="scope">
        <span v-if="scope.row.edit === false">
          <el-row>
            <el-col :span="14" style="padding-left:0px;padding-right:0px">
              <el-select
                v-model="scope.row.auditStatus"
                placeholder="请选择..."
              >
                <el-option
                  v-for="item in options"
                  :key="item.value"
                  :label="item.label"
                  :value="item.value"
                />
              </el-select>
            </el-col>
            <el-col
              :span="6"
              style="padding-left:0px;padding-right:0px;margin-top:2px;"
            >
              <span
                style="color:blue ;cursor:pointer;margin-top:2px;"
                @click="changeSave(scope.row.index, scope.row)"
              >
                <CircleCheck
                  style="color:#4F8AFF ;width:16px;height:16px;cursor:pointer;margin- 
                 bottom: -3px;"
                />
              </span>
              <span
                style="color:blue ;cursor:pointer;margin-top:2px;"
                @click="changeOff(scope.row.index, scope.row)"
              >
                <CircleClose
                  style="color:#4F8AFF ;width:16px;height:16px;cursor:pointer;margin- 
                 bottom: -3px;margin-left: 5px;"
                />
              </span>
            </el-col>
          </el-row>
        </span>
        <span
          class="spanan"
          v-if="scope.row.edit === true"
          @click="changeOn(scope.row.index)"
        >
          { { scope.row.auditStatus }}
          <Edit
           style="marginleft:10px;color:#4F8AFF;width:16px;height:16px;cursor:pointer;margin-bottom: 
           -3px;"
          />
        </span>
      </template>
    </el-table-column>

// 取消

const changeOff = (index, row) => {
  data.tableData[index].edit = true;
  ElMessage({
    showClose: true,
    type: 'info',
    message: '取消操作 !',
  });
};

// 打开
const changeShow = i => {

//该步是为了让我们每次只能打开一项
  data.tableData.forEach(item => {
    item.edit = true;
  });
  data.tableData[i].edit = false;
};

//保存

const changeSave = async (index, row) => {
  data.tableData[index].edit = true;
}

最近更新

  1. TCP协议是安全的吗?

    2023-12-15 09:00:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-15 09:00:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-15 09:00:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-15 09:00:02       20 阅读

热门阅读

  1. 【数据库设计和SQL基础语法】--查询数据--排序

    2023-12-15 09:00:02       34 阅读
  2. Web3.0和WebAssembly

    2023-12-15 09:00:02       30 阅读
  3. 【影像组学入门百问】#22—#24

    2023-12-15 09:00:02       33 阅读
  4. Git 的基本概念和使用方式。

    2023-12-15 09:00:02       35 阅读
  5. STM32系统滴答定时器SysTick实现精确ms和us延时

    2023-12-15 09:00:02       36 阅读
  6. 路由和网络周期

    2023-12-15 09:00:02       35 阅读
  7. android 13.0 Launcher3禁止拖拽app图标到第一屏

    2023-12-15 09:00:02       39 阅读
  8. 苏银消金大手笔增资,江苏银行持股比例上升

    2023-12-15 09:00:02       43 阅读
  9. 【bash】Bash脚本基础语法学习

    2023-12-15 09:00:02       34 阅读
  10. Bash script进阶笔记

    2023-12-15 09:00:02       34 阅读
  11. Python多线程编程:竞争问题的解析与应对策略

    2023-12-15 09:00:02       37 阅读
  12. windows MinGW C语言编译器安装及环境变量配置教程

    2023-12-15 09:00:02       34 阅读