亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue3中nextTick()應(yīng)用實(shí)例詳解

 更新時(shí)間:2023年12月07日 15:06:36   作者:江城開朗的豌豆  
這篇文章主要給大家介紹了關(guān)于vue3中nextTick()應(yīng)用的相關(guān)資料,nextTick()等待下一次DOM更新刷新的工具方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

在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 中mixin 的用法詳解

    Vue 中mixin 的用法詳解

    e中提供了一種混合機(jī)制--mixins,用來更高效的實(shí)現(xiàn)組件內(nèi)容的復(fù)用。這篇文章主要介紹了Vue mixin 的用法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2018-04-04
  • vue實(shí)現(xiàn)登陸頁面開發(fā)實(shí)踐

    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-05
  • vue-cli3配置favicon.ico和title的流程

    vue-cli3配置favicon.ico和title的流程

    這篇文章主要介紹了vue-cli3配置favicon.ico和title的流程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • 淺析一下Vue3的響應(yīng)式原理

    淺析一下Vue3的響應(yīng)式原理

    這篇文章主要通過示例和大家一起淺析一下Vue3的響應(yīng)式原理,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Vue3有一定幫助,需要的可以參考一下
    2022-08-08
  • Vue 開發(fā)必須知道的36個(gè)技巧(小結(jié))

    Vue 開發(fā)必須知道的36個(gè)技巧(小結(jié))

    這篇文章主要介紹了Vue 開發(fā)必須知道的36個(gè)技巧(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Vuejs2 + Webpack框架里,模擬下載的實(shí)例講解

    Vuejs2 + Webpack框架里,模擬下載的實(shí)例講解

    今天小編就為大家分享一篇Vuejs2 + Webpack框架里,模擬下載的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • Vuex mutitons和actions初使用詳解

    Vuex mutitons和actions初使用詳解

    這篇文章主要介紹了Vuex mutitons和actions初使用詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • Vue兼容ie9的問題全面解決方案

    Vue兼容ie9的問題全面解決方案

    這篇文章主要介紹了Vue兼容ie9的問題全面解決方案,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06
  • vue中的加密方式總結(jié)

    vue中的加密方式總結(jié)

    這篇文章主要為大家詳細(xì)介紹了vue中常見的加密方式實(shí)現(xiàn),例如js-base64、crypto-js、jsencrypt、bcryptjs,文中的示例代碼講解詳細(xì),需要的小伙伴可以參考一下
    2023-11-11
  • 在Vue3中實(shí)現(xiàn)虛擬列表的方法示例

    在Vue3中實(shí)現(xiàn)虛擬列表的方法示例

    文章主要介紹在 Vue3 中實(shí)現(xiàn)虛擬列表的方法,包括原理和代碼實(shí)現(xiàn),原理是只渲染可視區(qū)域內(nèi)的列表項(xiàng),通過設(shè)置子數(shù)據(jù)項(xiàng)高度、計(jì)算可視區(qū)域、渲染可視區(qū)域、滾動(dòng)監(jiān)聽、設(shè)置緩沖列表項(xiàng)等提升性能,感興趣的小伙伴跟著小編一起來看看吧
    2025-01-01

最新評(píng)論