前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue 改变数据,页面不刷新的问题

Vue 改变数据,页面不刷新的问题

作者头像
谭光志
发布2020-09-28 10:43:30
3.3K0
发布2020-09-28 10:43:30
举报
文章被收录于专栏:编程技术分享编程技术分享

最近在用 element-ui 开发一个网站,使用 table 组件时,发现修改完数据,有时候会延迟一两秒,页面才会发生变化。

在这里插入图片描述
在这里插入图片描述

看了一下代码,发现修改数据的代码是这样的

代码语言:javascript
复制
// popupData是修改的数据,修改完后,赋值给对应的表格数据
this.tableData[this.currentRow] = this.popupData
注意事项(以下内容摘自官方文档

由于 JavaScript 的限制,Vue 不能检测以下数组的变动:

  1. 当你利用索引直接设置一个数组项时,例如:vm.items[indexOfItem] = newValue
  2. 当你修改数组的长度时,例如:vm.items.length = newLength

举个例子:

代码语言:javascript
复制
var vm = new Vue({
  data: {
    items: ['a', 'b', 'c']
  }
})
vm.items[1] = 'x' // 不是响应性的
vm.items.length = 2 // 不是响应性的

为了解决第一类问题,以下两种方式都可以实现和 vm.items[indexOfItem] = newValue 相同的效果,同时也将在响应式系统内触发状态更新:

代码语言:javascript
复制
// Vue.set
Vue.set(vm.items, indexOfItem, newValue)
代码语言:javascript
复制
// Array.prototype.splice
vm.items.splice(indexOfItem, 1, newValue)

你也可以使用 vm.$set 实例方法,该方法是全局方法 Vue.set 的一个别名:

代码语言:javascript
复制
vm.$set(vm.items, indexOfItem, newValue)

为了解决第二类问题,你可以使用 splice

代码语言:javascript
复制
vm.items.splice(newLength)

所以,解决方法就是用 Vue.set 来代替直接赋值

代码语言:javascript
复制
this.$set(this.tableData, this.currentRow, this.popupData)
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 注意事项(以下内容摘自官方文档)
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档