中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue3生命周期原理與函數應用的方法是什么

發布時間:2023-04-21 15:59:37 來源:億速云 閱讀:86 作者:iii 欄目:開發技術

這篇“vue3生命周期原理與函數應用的方法是什么”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“vue3生命周期原理與函數應用的方法是什么”文章吧。

原理概述

Vue 3的生命周期(Lifecycle)指的是組件從創建到銷毀經歷的一系列事件,在這些事件中可以執行一些操作,例如初始化數據、渲染視圖、加載異步數據等。在Vue 3中,通過setup()函數來定義組件的生命周期。

實例分析

Vue 3的生命周期包含了以下幾個階段:

1. beforeCreate

在實例創建之前,即在初始化之前被調用。此時,尚未初始化組件實例,無法訪問data、methods和computed等屬性,在組件狀態初始化之前執行一些操作。

export default {
  beforeCreate() {
    console.log('beforeCreate');
  }
}

2. created

在實例創建之后,即在初始化之后被調用。此時,已經完成了數據觀測等配置,但尚未掛載DOM,并且可以訪問data、methods和computed等屬性。可以使用created鉤子函數進行數據初始化和事件的監聽等操作。

import { onMounted, onUnmounted } from 'vue';

export default {
  data() {
    return {
      count: 0
    };
  },
  created() {
    console.log('created');
  },
  mounted() {
    onMounted(() => {
      console.log('component mounted');
    });
  },
  unmounted() {
    onUnmounted(() => {
      console.log('component unmounted');
    });
  }
}

3. beforeMount

在掛載開始之前被調用。在此階段中,尚未渲染真實的DOM節點。可以使用beforeMount鉤子函數,在組件掛載之前進行一些異步操作,例如加載動畫等。

export default {
  beforeMount() {
    console.log('beforeMount');
  }
}

4. mounted

在掛載結束后被調用。此時,組件已經渲染出真實的DOM。mounted鉤子函數往往用于初始化DOM操作以及與服務器交互后填充組件的數據,例如通過ref獲取DOM節點和注冊事件監聽器等。

export default {
  mounted() {
    console.log('mounted');
    const button = this.$refs.myButton;
    button.addEventListener('click', () => {
      this.count++;
    });
  }
}

5. beforeUpdate

在數據更新之前被調用。此時,可以在更新之前訪問舊的數據狀態。可以使用beforeUpdate鉤子函數,在組件數據更新之前執行一些操作,例如動態綁定class和style等。

export default {
  beforeUpdate() {
    console.log('beforeUpdate');
  }
}

6. updated

在數據更新之后被調用。此時,組件已經更新DOM,可以通過訪問最新的數據狀態來完成DOM的操作。可以使用updated鉤子函數,在組件數據更新之后執行一些操作,例如觸發動畫效果等。

export default {
  updated() {
    console.log('updated');
  }
}

7. beforeUnmount

在組件卸載之前被調用。此時,組件實例仍然完全可用,但是它的視圖已經被銷毀并且不再更新。可以使用beforeUnmount鉤子函數,在組件卸載之前執行一些清理操作,例如取消事件監聽器、定時器和異步請求等。

export default {
  beforeUnmount() {
    console.log('beforeUnmount');
  }
}

8. unmounted

在組件卸載之后被調用。此時,組件實例以及其所有相關聯的DOM元素均已銷毀,無法再訪問組件內部數據和方法。可以使用unmounted鉤子函數,在組件卸載之后執行一些最終清理操作。

export default {
  unmounted() {
    console.log('unmounted');
  }
}

需要注意的是,Vue 3中去掉了一些生命周期函數,例如activated、deactivated和errorCaptured等,這些可以通過新的Composition API來實現。

以上就是關于“vue3生命周期原理與函數應用的方法是什么”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武鸣县| 油尖旺区| 大港区| 霍山县| 德州市| 广德县| 台湾省| 莱芜市| 游戏| 大庆市| 沧源| 和林格尔县| 洛扎县| 嘉荫县| 西昌市| 罗城| 阜新市| 金坛市| 微山县| 淅川县| 贵阳市| 西青区| 乌海市| 新营市| 望谟县| 承德县| 手游| 子长县| 大理市| 竹山县| 祁门县| 时尚| 灵武市| 沂南县| 太仆寺旗| 香格里拉县| 琼海市| 高州市| 开化县| 湘西| 奈曼旗|