formatter的用法,深拷贝, Object.assign 方法实战。

  1. :formatter的用法 :formatter 接受一个函数作为参数,这个函数有三个参数:row,column 和 cellValue。row 是当前行的数据,column 是当前列的数据,cellValue 是当前单元格的值。
javascript 复制代码
   <el-table-column prop="SYSC" label="试用时长(月)" 
                           :formatter="row => row.JZORSY === '兼职' ? '' : row.SYSC">
                          </el-table-column>

                          <el-table-column prop="JZORSY" label="兼职或试用">
                          </el-table-column>

2.在表格所在行点击编辑,打开弹窗。修改内容,没有点击确定的时候,表格的数据会随着编辑的更新而更新,这是由于数据没有序列化,使用JOSN进行一次序列号。这样row与this.familyPerson.familyPersonForm指向的就不在是一个地址,但是导致的问题则是编辑后点击确定无法更新表格数据。

javascript 复制代码
   let _familyPersonForm = JSON.stringify(row)
      this.familyPerson.familyPersonForm = JSON.parse(_familyPersonForm);

解决方法:

javascript 复制代码
   editFamilyPerson(row, column, event) {
      this.jtMoreIndex = 1;
      this.editData = JSON.parse(JSON.stringify(row));
      this.familyPerson.editId = row.id;
      this.familyPerson.familyPersonForm= this.editData 
      this.familyPerson.familyPersonDialogVisible = true;
    },

    // 编辑完后
    onEditComplete() {
      let row = this.familyPerson.list.find(item => item.id === this.familyPerson.editId);
      Object.assign(row, this.editData);
      this.familyPerson.familyPersonDialogVisible = false;
    },

创建了一个 editData 对象,这是通过深拷贝 row 对象得到的。这样做的目的是为了避免直接修改 row 对象,因为 row 对象是直接从父组件传递过来的,直接修改它可能会导致一些不可预见的问题。

然后,你将 editData 对象赋值给 familyPerson.familyPersonForm,这样就可以在表单中显示和编辑这些数据了。

在 onEditComplete 方法中,使用 Object.assign方法将 editData 对象的内容复制到了原始数据中。这样做的目的是为了更新原始数据,而不是创建一个新的对象。这是因为 Object.assign 方法会修改目标对象(即 row 对象),而不是创建一个新的对象。

相关推荐
小码哥_常1 小时前
安卓开发秘籍:解锁10大性能优化秘诀
前端
谁呛我名字2 小时前
JavaScript 类型转换与运算规则
javascript
try2find3 小时前
打印ascii码报错问题
java·linux·前端
郑州光合科技余经理3 小时前
同城O2O海外版二次开发实战:从支付网关到配送算法
开发语言·前端·后端·算法·架构·uni-app·php
冰暮流星3 小时前
javascript事件案例-全选框案例
服务器·前端·javascript
Dillon Dong4 小时前
【系列主题】Next.js 16 + Turbopack 的暗礁:深入剖析 Tailwind v4 的 CSS 模块解析陷阱
javascript·css·容器·turbopack
Csvn4 小时前
前端性能优化实战指南
前端
Moment4 小时前
2026 年,AI 全栈时代到了,前端简历别再只写前端技术了 🫠🫠🫠
前端·后端·面试
糯米团子7494 小时前
Web Worker
开发语言·前端·javascript
freewlt4 小时前
React Server Components 深度解析
前端·react.js·前端框架