Vue 数值改变 页面没有刷新(解决数据改变视图不更新的问题)

当Vue表格数据通过解构赋值修改后,页面未刷新显示新值。原因在于解构赋值在多层数据结构下是浅拷贝。解决方案包括直接赋值、使用$set、JSON转换以及利用v-if和$nextTick。对于包含render函数的表格,可通过添加tablekey强制重新渲染。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

情况描述

值(List)修改后,打印值改变了,但页面数据没刷新

  • 如何赋值:this.tableData[index] = { ...this.tableData[index], ...result }
  • 想法:利用解构赋值,修改对应key的value值
  • 例:this.tableData[index] = {id:1,name:jarry} result={id:2}

原因

解构赋值
如果所解构的原对象是一维数组或对象,其本质就是对基本数据类型进行等号赋值,那它就是深拷贝;
如果是多维数组或对象,其本质就是对引用类型数据进项等号赋值,那它就是浅拷贝;
最终的结论就是:解构赋值是浅拷贝(因为它确实不能对多维数组或对象达到深拷贝的作用);

解决方案

  • 1.直接赋值
  Object.keys(result).forEach(item => {
     this.tableData[index][item] = result[item];
 })
  • 2.$set
  Object.keys(result).forEach(item => {
    this.$set(this.tableData[index], item, result[item])
 })
  • 3.重新赋值JSON.parse(JSON.stringify(this.tableData))
 this.tableData[index] = { ...this.tableData[index], ...result };
  this.tableData = JSON.parse(JSON.stringify(this.tableData))
  • 4.v-if&&this.$nextTick 重新渲染页面
 <Table :columns="columns" :data="tableData"  v-if="isTable"></Table>
 this.$nextTick(()=>{
     this.isTable = true;
  })

当表格数据改变,表格没刷新时,并且使用了render

例如:如下是增加了表格可展开行,但是展开行在重新赋值时并没有更新页面
在这里插入图片描述

 columns: [
     {
       type: "expand",
       width: 30,
       align: "center",
       render: (h, params) => {
         return h(
           "div",
           {
             style: {
               padding: "5px 0 5px 30px",
               backgroundColor: "#fff",
             },
           },
           [
             h("Table", {
               props: {
                 border: true,
                 columns: this.columns1,
                 data: this.data[params.index].children || [],
                 tablekey: this.tablekey,
               },
             }),
           ]
         );
       },
     }
]

解决方案

  • 添加tablekey,当赋值以后,this.tablekey++
  • 在这里插入图片描述
this.data.forEach((item) => {
    if (item.id === id) {
      let result = res.result || [];
      item.children = result;
      this.submitBindData.ids = result.map((o) => o.id).join(",");
    }
  });
  ++this.tablekey;
### ECharts 数据更新视图未同步刷新解决方案 在使用 ECharts 的过程中,如果发现数据已经更新视图未能及时刷新,通常是因为 `setOption` 方法并未被正确调用或者存在其他潜在问题。以下是针对此问题的具体分析和解决方法: #### 1. 清空图表实例后再设置新配置项 当需要频繁更新图表的数据时,建议在每次调用 `setOption` 前先清除当前实例中的所有组件和图表。这可以通过调用 `clear()` 方法实现[^1]。 ```javascript updateGaugeChart(num = 0) { let option = { series: [{ type: 'gauge', data: [{ value: num }] }] }; this.gaugeChart.clear(); // 清空现有图表内容 this.gaugeChart.setOption(option); // 设置新的配置项 } ``` 上述代码片段展示了如何在更新数据之前清理旧的内容,确保会因残留数据而导致显示异常。 --- #### 2. 使用 Vue 组件通信机制传递最新数据 对于基于 Vue.js 开发的应用程序,在父组件中动态获取的新数据可能无法自动触发子组件(即 ECharts 图表)重新渲染。此时可以采用以下方式来解决问题[^3]: - **绑定 Props 并监听变化** 将父组件传来的数据作为 Prop 接收,并利用 Vue 的响应式特性检测其变动。一旦接收到新的数据,则立即执行 `setOption` 或者重绘逻辑。 ```vue <template> <div id="chart"></div> </template> <script> export default { props: ['chartsData'], watch: { chartsData(newVal, oldVal) { if (newVal !== oldVal && newVal.length > 0) { this.updateChart(); } } }, methods: { updateChart() { const processedData = this.chartsData.map(item => item.value); const option = { /* 动态生成选项 */ }; this.myChart.setOption(option); } }, mounted() { this.myChart = echarts.init(this.$el); } }; </script> ``` 在此示例中,每当 `chartsData` 发生改变时都会触发动态计算并应用最新的配置参数至 ECharts 实例上。 --- #### 3. 性能优化策略下的注意事项 尽管直接调用 `setOption` 可以完成大部分场景的需求,但在大规模复杂图形渲染环境下仍需注意性能开销。例如,避免必要的 DOM 操作以及减少重复绘制次数等措施能够显著提升效率[^4]。 一种常见的做法是在初始化阶段仅定义基础结构框架部分(如坐标轴样式),而将具体数值填充延迟到后续按需加载环节;另外还可以考虑启用增量更新模式——只替换那些确实发生变化的部分而非整体重建整个画面布局。 --- #### 结论 综上所述,要有效应对 ECharts 中由于数据变更引起界面同步的现象,可以从以下几个方面入手: - 明确调用顺序:优先执行 `clear()` 来释放资源; - 利用前端框架特有的双向绑定功能简化流程控制; - 关注实际业务需求合理规划架构设计从而兼顾用户体验与运行速度之间的平衡关系。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值