vue 视图更新不及时

vue开发的过程中我们时常会遇到 数据更新和视图更新 不匹配的问题。简单点说就是vue没有监测到这一块儿的数据变化。

简单的解决方法有几种

vue2 中

// 第一种:
// Vue.set() 方法(this.$set())
Vue.set( target, key, value ) 中有三个参数给我们
 
this.$set(this.student,"age", 24)

// target:要更改的数据源(可以是对象或者数组)
// key:要更改的具体数据 如果是数组 就是索引值
// value :重新赋的值
// 第二种:
// $forceUpdate 主动捕获并刷新视图数据

// 异步中
data(){
	return {
		list: [3,2,1]
	}
}
···
this.list = [1,2,3] // 在更新数据的后边跟一句刷新数据的操作即可
this.$forceUpdate()
// 第三种
// 直接将异步数据转同步操作【不建议这么操作,具体方法不详细说明了】

vue3中

// vue3 中相对简单
// 因为vue3 中会提前使用ref或者是reactive 定义变量,正常情况下异步也会同步数据到视图中。
// 但是如果出现网络延迟,接口有严格调用顺序的也会出现视图更新问题,所以我个人的做法是采用上述vue2中的第二种方法。
import { getCurrentInstance } from "vue";
setup(){
	// 解构赋值 
	// 设置一个自定义名称 that 或者直接用ctx 
  	let {ctx:that} = getCurrentInstance()
	that.$forceUpdate()

	//	let ctx= getCurrentInstance()
	//	ctx.$forceUpdate()
}


  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值