首页 前端知识 el-table 里面嵌套el-input 数据改变了但是页面没有同步更新(全网最全)

el-table 里面嵌套el-input 数据改变了但是页面没有同步更新(全网最全)

2024-04-29 11:04:07 前端知识 前端哥 339 829 我要收藏

解决方案(经测试过可以使用的)

一:动态生成的key值绑定在el-table上

  <el-table :data="currentRecordList" :key="isUpdate">
        <el-table-column prop="address" label="Sender" min-width="10%" />
        <el-table-column prop="date" label="Date" min-width="15%" />
        <el-table-column label="Message conten" min-width="40%">
          <template slot-scope="scope">
            <span v-if="scope.row.bodyHighlights" v-html="scope.row.bodyHighlights"></span>
            <span v-else>{{ scope.row.body }}</span>
          </template>
        </el-table-column>
     </el-table>

在数据更新的地方后面加上如下

this.isUpdate = !this.isUpdate;

为什么?

key 的特殊属性主要用在 Vue 的虚拟 DOM 算法,在新旧节点对比时辨识vnodes。

如果不使用 key,Vue 会使用一种最大限度减少动态元素并且尽可能的尝试就地修改/复用相同类型元素的算法。

而使用 key 时,它会基于 key 的变化重新排列元素顺序,并且会移除 key 不存在的元素。

有相同父元素的子元素必须有独特的 key。重复的 key 会造成渲染错误。

因此,通过修改绑定在 table 上面的 key 值,可以触发 el-table 的重新渲染

可以设置随机数 、uuid(唯一值)0 ( this.num ++)或者布尔值
1.随机数

Math.random()
//生成一个随机数,强制刷新列表进行渲染

2.uuid

// 获取唯一id
export function getid() {
  const r = URL.createObjectURL(new Blob());
  return r.substr(r.lastIndexOf("/") + 1, r.length - 1);
}


import { getid } from "@/utils/uuid.js"; // 引入getid
this.uuid = getid();

缺点:

但会导致界面强制刷新,体验感很差

二:把生成的key值绑定在el-input框上 (推荐)

优点:

刷新而且效果可以

为什么更新了呢?

在这里插入图片描述

三:随便调用 页面其他事件 达到页面改变刷新数据 (推荐)

参考

      		// 改变第一行数据
			changeRowData(){
				this.tableData[0].name = 'zz'
				// 数据并不会更新, 随便调用一下页面事件,什么事件都可以,聚焦等都可以,这里使用 element 表格自带的高亮行事件
         		 this.$refs.table.setCurrentRow(this.tableData[0])
			},


博主这里尝试了clearSelection方法可以成功~

  // this.$refs.addEditSeeTableRef.clearSelection();

失败方法

  1. this.$set进行修改单元格数据在这里插入图片描述

  2. this.$set进行修改一行的数据
    在这里插入图片描述
    也有的人说可以 参考

可能是因为嵌套过深的问题

this.$set(this.curHomePageExchangeGoodsList, index, tmpObj);

没有尝试的方法

  1. this.$forceUpdate();进行强制更新 (大多数人说是依然无效)
  2. 更改引用,创建一个新的数组或对象,替换旧的数组或对象,这将强制 Vue 更新视图 (这个感觉可以)
// 对于数组
this.maf_version_list = [...this.maf_version_list];

// 对于对象
this.maf_empty_version = { ...this.maf_empty_version };

  1. 深拷贝 在每次操作完数据之后重新给表单赋值JSON.parse(JSON.stringify(this.tableData)) 跟上面的一样都是改变对象的引用地址
  2. 修改为input 来写 用el-input就不能做响应式,所以用了input然后再把el-input的css样式copy了
    测试过el-input是可以做到响应式的 可以去自测一下

相关文章

js 保留两位小数–乘以100或除以100之后 小数为5没有四舍五入

如何把本地的vue项目写的组件上传到npm

❤ 最后:

需要进入技术交流群可私聊哈,都是一群爱分享和捣鼓各种奇思妙想的伙伴哦~

转载请注明出处或者链接地址:https://www.qianduange.cn//article/6212.html
标签
评论
发布的文章

JQuery中的load()、$

2024-05-10 08:05:15

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!