VUE this.$nextTick()异步刷新页面通俗用法
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了VUE this.$nextTick()异步刷新页面通俗用法相关的知识,希望对你有一定的参考价值。
参考技术A this.$nextTick()的官方解释是:将回调延迟到下次 DOM 更新循环之后执行。看了这句话后我的状态是这样的:
其实这个方法很好理解,也超好用噢。
通俗解释就是(扣个脚解释):this.$nextTick()括号中的东西会放在最后执行。就这么简单,就算this.$nextTick()放在最前面都好,一样放在最后执行。
贴上例子:
// 点击事件
dianjishijian ()
// 这里面的东西最后执行
this.$nextTick(() =>
alert('我在这个点击事件中最后执行')
)
alert('我比那哥们儿先执行')
,
this.$nextTick()的使用
背景
在一个vue结合elementui的项目实现点击再一次增加会员的按钮时,清空上一次输入框里的数据,采用this.$refs[‘ruleForm‘].resetFields()
,但是却报错,无法获取dom。那么此时快速的解决办法就是使用this.$nextTick()方法。
使用场景
this.$nextTick()方法主要是用在随数据改变而改变的dom应用场景中,vue中数据和dom渲染由于是异步的,所以,要让dom结构随数据改变这样的操作都应该放进this.$nextTick()的回调函数中。created()中使用的方法时,dom还没有渲染,如果此时在该钩子函数中进行dom赋值数据(或者其它dom操作)时无异于徒劳,所以,此时this.$nextTick()就会被大量使用,而与created()对应的是mounted()的钩子函数则是在dom完全渲染后才开始渲染数据,所以在mounted()中操作dom基本不会存在渲染问题。
使用具体方式
以上是关于VUE this.$nextTick()异步刷新页面通俗用法的主要内容,如果未能解决你的问题,请参考以下文章