如何用vue2+element-ui实现多行行内表格编辑

 更新时间:2024年08月21日 08:32:01   作者:没资格抱怨  
最近开发项目,关于表格的数据操作比较多,这个地方个人觉得比较难搞,特此记录一下,这篇文章主要给大家介绍了关于如何用vue2+element-ui实现多行行内表格编辑的相关资料,需要的朋友可以参考下

效果图展示

当在表格中点击编辑按钮时:

点击的行变成文本框且数据回显可以点击确定按钮修改数据或者取消修改回退数据:

具体实现步骤

1. 行数据定义编辑标记

行数据定义编辑标记

当在组件中获取到用于表格展示数据的方法中,针对每一行数据添加一个编辑标记

this.list.forEach(item => {
        // item.isEdit = false // 添加一个属性 初始值为false
        // 数据响应式的问题  数据变化 视图更新
        // 添加的动态属性 不具备响应式特点
        // this.$set(目标对象, 属性名称, 初始值) 可以针对目标对象 添加的属性 添加响应式
        this.$set(item, 'isEdit', false)
      })

 注意:为什么不使用item.isEdit = false , 因为动态添加的属性不具备响应式的特点,如果想要具备响应式,可以使用$set

2. 点击行编辑标记状态(isEdit)

点击编辑时,将当前行的标记isEdit设置为true

<el-table-column align="center" label="操作">
    <template>
        <!-- 非编辑状态 -->
        <el-button size="mini" type="text">分配权限</el-button>
        <el-button size="mini" type="text" @click="btnEditRow(row)">编辑</el-button>
        <el-button size="mini" type="text">删除</el-button>
    </template>
</el-table-column>

点击编辑的方法

// 点击编辑行
btnEditRow(row) {
  row.isEdit = true // 改变行的编辑状态
}

3. 插槽根据标记渲染表单

el-table-column组件中使用<template v-slot="{ row }">作用域插槽获取当前行的信息

所以在表格列中可以借助当前行的信息根据当前的isEdit标记-渲染结构

<el-table-column prop="name" align="center" width="200" label="角色">
      <template v-slot="{ row }">
        <!-- 条件判断 -->
        <el-input v-if="row.isEdit" size="mini" />
        <span v-else>{{ row.name }}</span>
      </template>
</el-table-column>
<el-table-column prop="state" align="center" width="200" label="启用">
          <!-- 自定义列结构 -->
    <template v-slot="{ row }">
        <el-switch v-if="row.isEdit" />
        <span v-else>  {{ row.state === 1 ? "已启用" : row.state === 0 ? "未启用" : "无" }} </span>
    </template>
</el-table-column>

$set的应用

  • this.$set(目标对象, 属性名称, 初始值 )
  • 等价于 Vue.set(目标对象, 属性名称, 初始值)
  • 向响应式对象中添加一个属性,并确保这个新属性同样是响应式的,且触发视图更新。

行内编辑-数据缓存

行内编辑需要做数据缓存

为什么要做数据缓存?

因为编辑时,可以取消会滚到之前的状态,所以编辑时的数据是临时的数据。

假设list数组中的name,state,description三个属性是用于表格每列展示的数据,当进行行内编辑时需要将这3个属性进行缓存,因为编辑的数据是临时的

如图,editRow的数据是针对当前行的数据做了一份拷贝,针对这个拷贝,我们可以随意修改。

1. 初始化时缓存数据

//缓存数据
this.list.forEach(item => {
        this.$set(item, 'isEdit', false)
        this.$set(item, 'editRow', {
          name: item.name,
          state: item.state,
          description: item.description
        })
  })

2. 点击编辑时更新缓存数据

btnEditRow(row) {
      row.isEdit = true // 改变行的编辑状态
      // 更新缓存数据
      row.editRow.name = row.name
      row.editRow.state = row.state
      row.editRow.description = row.description
}

3. 将编辑时的表单双向绑定缓存数据

<el-table-column prop="name" align="center" width="200" label="角色">
          <template v-slot="{ row }">
            <!-- 条件判断 -->
            <!-- 编辑状态 -->
            <el-input v-if="row.isEdit" v-model="row.editRow.name" size="mini" />
            <!-- 非编辑状态 -->
            <span v-else>{{ row.name }}</span>
          </template>
</el-table-column>

行内编辑-确定取消按钮

1. 确定按钮

el-table中不能使用表单所以在确定按钮的回调中要进行手动判断

然后将编辑好的数据封装到一个对象中发起请求

下方使用Object.assign方法是因为发送完请求,数据库数据已更新,而前端页面也需要更新

<el-button type="primary" size="mini" @click="btnEditOK(row)">确定</el-button>

// 点击确定时触发
    async  btnEditOK(row) {
      if (row.editRow.name && row.editRow.description) {
        // 下一步操作
        await updateRole({ ...row.editRow, id: row.id })
        // 更新成功
        this.$message.success('更新角色成功')
        // 更新显示数据  退出编辑状态
        // row.name = row.editRow.name // eslint的一校验 误判
        // Object.assign(target, source)
        Object.assign(row, {
          ...row.editRow,
          isEdit: false // 退出编辑模式
        }) // 规避eslint的误判
      } else {
        this.$message.warning('角色和描述不能为空')
      }
    }

注意: 这里既然更新成功了,要把缓存数据回显到页面上,并且关闭编辑模式

2. 取消按钮

关闭编辑状态即可

<el-button size="mini" @click="row.isEdit = false">取消</el-button>

总结 

到此这篇关于如何用vue2+element-ui实现多行行内表格编辑的文章就介绍到这了,更多相关vue2+element-ui多行行内表格编辑内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue3 v-bind="$attrs"继承组件全部属性的解决方案

    vue3 v-bind="$attrs"继承组件全部属性的解决方案

    这篇文章主要介绍了vue3 v-bind=“$attrs“ 继承组件全部属性的解决方案,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06
  • el-table在弹窗中的使用示例详解

    el-table在弹窗中的使用示例详解

    本文总结了在Vue2项目中使用element-ui的el-table组件在弹窗中展示数据,并实现基础的勾选功能,内容包括如何设置row-key、使用reserve-selection属性、修改数据获取函数以支持跨页勾选以及如何在关闭弹窗时清理selection,感兴趣的朋友跟随小编一起看看吧
    2024-12-12
  • Vue和relation-graph库打造高质量的关系图应用程序

    Vue和relation-graph库打造高质量的关系图应用程序

    这篇文章主要介绍了Vue和relation-graph库打造高质量的关系图应用程序,在这篇文章中,我们深入探讨了如何使用Vue和relation-graph高效打造关系图,我们详细介绍了数据准备、关系映射、点击事件等关键步骤,需要的朋友可以参考下
    2023-09-09
  • Vue收集依赖与触发依赖源码刨析

    Vue收集依赖与触发依赖源码刨析

    vue对依赖的管理使用的是发布订阅者模式,其中watcher扮演订阅者,Dep扮演发布者。所以dep中会有多个watcher,一个订阅者也可以有多个发布者(依赖)。总共三个过程:定义依赖、收集依赖、触发依赖。下面开始详细讲解三个过程
    2022-10-10
  • element中el-table局部刷新的实现示例

    element中el-table局部刷新的实现示例

    本文主要介绍了element中el-table局部刷新的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • vue3中setup-script的应用实例

    vue3中setup-script的应用实例

    script-setup是一个比较有争议的新特性,作为 setup 函数的语法糖,褒贬不一,不过经历了几次迭代之后,目前在体验上来说,感受还是非常棒的,这篇文章主要给大家介绍了关于vue3中setup-script应用的相关资料,需要的朋友可以参考下
    2022-01-01
  • Vue echart实现柱状图,电池图,3D柱图和3D圆柱图代码详解

    Vue echart实现柱状图,电池图,3D柱图和3D圆柱图代码详解

    这篇文章主要为大家介绍了Vue实现echart绘图代码详解,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • vue中onmounted周期里获取不到dom的原因及分析

    vue中onmounted周期里获取不到dom的原因及分析

    这篇文章主要介绍了vue中onmounted周期里获取不到dom的原因及分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • Vue+Websocket简单实现聊天功能

    Vue+Websocket简单实现聊天功能

    这篇文章主要为大家详细介绍了Vue+Websocket简单实现聊天功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • 解决vue组件没显示,没起作用,没报错,但该显示的组件没显示问题

    解决vue组件没显示,没起作用,没报错,但该显示的组件没显示问题

    这篇文章主要介绍了解决vue组件没显示,没起作用,没报错,但该显示的组件没显示问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09

最新评论