$nextTick和$forceUpdate

本文详细解析了Vue.js中的两个关键方法:$nextTick与$forceUpdate的功能及应用场景。$nextTick确保在DOM更新后执行回调,适用于需要在数据变更后立即操作DOM的情形。$forceUpdate则用于强制组件重新渲染,适用于特定条件下Vue无法检测到的数据变化情况。
摘要由CSDN通过智能技术生成

vm.$nextTick( [callback] )

官方解释: 将回调延迟到下次 DOM 更新循环之后执行

要理解这句话,首先要了解一下vue的异步更新队列,Vue 异步执行 DOM 更新。只要观察到数据变化,不会立即更新DOM,Vue 将开启一个队列,并缓冲在同一事件循环中发生的所有数据改变。如果同一个 数据被的多次 改变,只会被推入到队列中一次。例如,当你设置 vm.someData = 'new value' ,对应的DOM更新会被推到一个队列里,该组件不会立即重新渲染,会在当前tick完毕后,在下一个tick中渲染DOM。在事件循环中,每进行一次循环操作称为tick。而nextTick函数就是vue提供的一个实例方法,数据更新后等待下一个tick里Dom更新完后执行回调,回调的 this 自动绑定到调用它的实例上。

例如:

html: 
<span class="test">{{egData}}</span>
<el-button @click="changeData">改变</el-button>

js:
new Vue({
	data () {
		return {
			egData: 'old Message'
		}
	}
    methods: {
        changeData () {
          this.egData = 'new Message'
          console.log($('.test').html(), '-----------------------')
        }
  	}
})
复制代码

结果: 第一次点击输出 old Message -----------------------,第二次点击输出 new Message -----------------------

使用$nextTick:

js:
new Vue({
	data () {
		return {
			egData: 'old Message'
		}
	}
    methods: {
        changeData () {
          this.egData = 'new Message'
          this.$nextTick(function () {
          	console.log($('.test').html(), '-----------------------')
          })
          
        }
  	}
})
复制代码

结果:不管第几次点击,都输出 new Message -----------------------

$nextTick使用场景:

1、数据更新后想要马上操作新的DOM,需要把操作写在nextTick的回调里

2、在created钩子函数里需要操作DOM,也可以把操作写在nextTick的回调里,(created钩子函数里还没有挂载dom,所以直接操作会有问题)

$forceUpdate()

迫使Vue实例重新(rander)渲染虚拟DOM,注意并不是重新加载组件。结合vue的生命周期,调用$forceUpdate后只会触发beforeUpdate和updated这两个钩子函数,不会触发其他的钩子函数。它仅仅影响实例本身和插入插槽内容的子组件,而不是所有子组件。

$forceUpdate()使用场景:

1、当在data里没有显示的声明一个对象的属性,而是之后给该对象添加属性,这种情况vue是检测不到数据变化的,可以使用$forceUpdate()

html:

<span class="test">{{egData.value}}</span>
<el-button @click="changeData">改变</el-button>

js:
egData: {}

...


changeData () {
    this.egData.value = 'oldValue'
    this.$forceUpdate()  // dom会更新
}

复制代码

但是这种做法并不推荐,官方说如果你现在的场景需要用forceUpdate方法 ,那么99%是你的操作有问题,如上data里不显示声明对象的属性,之后添加属性时正确的做法时用 vm.$set() 方法,所以forceUpdate请慎用

转载于:https://juejin.im/post/5ca56ac951882543d6528d11

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值