解决方案(经测试过可以使用的)
一:动态生成的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();
失败方法
-
this.$set进行修改单元格数据
-
this.$set进行修改一行的数据
也有的人说可以 参考
可能是因为嵌套过深的问题
this.$set(this.curHomePageExchangeGoodsList, index, tmpObj);
没有尝试的方法
- this.$forceUpdate();进行强制更新 (大多数人说是依然无效)
- 更改引用,创建一个新的数组或对象,替换旧的数组或对象,这将强制 Vue 更新视图 (这个感觉可以)
// 对于数组
this.maf_version_list = [...this.maf_version_list];
// 对于对象
this.maf_empty_version = { ...this.maf_empty_version };
- 深拷贝 在每次操作完数据之后重新给表单赋值JSON.parse(JSON.stringify(this.tableData)) 跟上面的一样都是改变对象的引用地址
- 修改为input 来写 用el-input就不能做响应式,所以用了input然后再把el-input的css样式copy了
测试过el-input是可以做到响应式的 可以去自测一下
相关文章
js 保留两位小数–乘以100或除以100之后 小数为5没有四舍五入
如何把本地的vue项目写的组件上传到npm
❤ 最后:
需要进入技术交流群可私聊哈,都是一群爱分享和捣鼓各种奇思妙想的伙伴哦~