如何解决vue2数据更新视图不更新

如何解决vue2数据更新视图不更新

因为vue2和vue3的执行机制有所不同,v2是通过object.defindProperty,监听对象新增或修改某一个属性的时候会触发,所以会出现数据更新视图不更新的情况,而v3则是通过es6的proxy监听整个对象的变化

当发生数据更新视图不更新时我们可以使用this.$set()来解决
对象:写法

data:{
	obj:{
		a:1,
		b:2,
	}
}
methods:{
	add(){
	//this.obj.c=10//给obj添加属性及属性值
	//	console.log(this.obj)//obj发生了变化,但是视图并未更新
	this.$set(this.obj,"c",10)//这时候就可以用到this.$set()来强制更新
		//语法为this.$set(变化的值,"新增属性/下标",新增的值)
	}
}

数组写法:

data:{
	arr:[1,2,3,4]
},
methods:{
	add(){
		//arr[arr.length]=999
		this.$set(this.arr,this.arr.length,999)
	}
}

除此之外我们还有一种方法

data:{
	arr:[1,2,3,4]
},
methods:{
	add(){
		arr[arr.length]=999
		this.arr=JSON.parse(JSON.stringify(this.obj))//这样也可以解决
	}
}
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值