vue3中nextTick()應(yīng)用實(shí)例詳解
前言
在Vue3中,可以使用nextTick
函數(shù)來延遲執(zhí)行某些操作,這些操作會(huì)在下一次DOM更新周期之后執(zhí)行。這個(gè)函數(shù)通常用于在數(shù)據(jù)更新后,等待DOM更新之后執(zhí)行一些操作,比如獲取DOM元素的尺寸、位置等。
nextTick()
例如,以下一個(gè)切換元素顯示的組件:
<template> <div> <button @click="handleClick">顯示/移除</button> <div v-if="show" ref="content">我是一個(gè)元素</div> </div> </template> <script setup> import { ref } from 'vue' const show = ref(true) const content = ref() const handleClick = () => { show.value = !show.value console.log(show.value, content.value)//true null } </script>
打印結(jié)果:
如果show是true,那么content是null,這意味著 DOM 與組件的數(shù)據(jù)不同步。
我們加上nextTick()
<template> <div> <button @click="handleClick">顯示/移除</button> <div v-if="show" ref="content">我是一個(gè)元素</div> </div> </template> <script setup> import { ref, nextTick } from 'vue' const show = ref(true) const content = ref() const handleClick = () => { show.value = !show.value nextTick(() => { console.log(show.value, content.value) }) } </script>
打印結(jié)果:
當(dāng)show為true時(shí),獲取到dom。
nextTick() 與異步/等待
如果nextTick()不帶參數(shù)調(diào)用,則該函數(shù)返回一個(gè)promise
,該promise
在組件數(shù)據(jù)更改到達(dá) DOM 時(shí)解析。
這有助于利用更具可讀性的async/await語法。 如下例子:
<template> <div> <button @click="handleClick">顯示/移除</button> <div v-if="show" ref="content">我是一個(gè)元素</div> </div> </template> <script setup> import { ref, nextTick } from 'vue' const show = ref(true) const content = ref() const handleClick = async () => { show.value = !show.value console.log(show.value, content.value) await nextTick() console.log(show.value, content.value) } </script>
執(zhí)行結(jié)果:
總結(jié)
當(dāng)你更改組件的數(shù)據(jù)時(shí),Vue3 會(huì)異步更新 DOM。
如果你想捕捉組件數(shù)據(jù)變化后 DOM 更新的時(shí)刻,那么你需要使用nextTick(callback)
函數(shù)。
它們的單個(gè)callback參數(shù)在 DOM 更新后立即被調(diào)用:并且你可以保證獲得與組件數(shù)據(jù)同步的最新 DOM。
或者,如果你不向nextTick()
提供回調(diào)參數(shù),那么這些函數(shù)將返回一個(gè)在 DOM 更新時(shí)被解析的promise
。
到此這篇關(guān)于vue3中nextTick()應(yīng)用的文章就介紹到這了,更多相關(guān)vue3 nextTick()應(yīng)用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue實(shí)現(xiàn)登陸頁面開發(fā)實(shí)踐
本文主要介紹了vue實(shí)現(xiàn)登陸頁面開發(fā)實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05vue-cli3配置favicon.ico和title的流程
這篇文章主要介紹了vue-cli3配置favicon.ico和title的流程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-10-10Vue 開發(fā)必須知道的36個(gè)技巧(小結(jié))
這篇文章主要介紹了Vue 開發(fā)必須知道的36個(gè)技巧(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10Vuejs2 + Webpack框架里,模擬下載的實(shí)例講解
今天小編就為大家分享一篇Vuejs2 + Webpack框架里,模擬下載的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09