欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何使用Vue3的onMounted鉤子函數(shù)及vue3中onMounted的用法詳解

 更新時(shí)間:2024年11月15日 10:27:48   作者:watermelo37  
本文詳細(xì)介紹了Vue3中的`onMounted`鉤子函數(shù)的前世今生,包括其在Vue2中的前身`mounted`鉤子,以及Vue3中使用Composition?API的`onMounted`鉤子的用法,文章涵蓋了`onMounted`的多種用法,感興趣的朋友跟隨小編一起看看吧

一、onMounted的前世今生

1.1、onMounted是什么

        onMounted鉤子函數(shù)在組件實(shí)例被成功掛載后調(diào)用,此時(shí)你可以訪問(wèn)到 DOM 元素。它返回一個(gè)函數(shù),可以用于在組件卸載時(shí)進(jìn)行清理(比如Interval等)。

        可以說(shuō)onMounted鉤子函數(shù)是最常用的鉤子函數(shù)了,玩轉(zhuǎn)onMounted鉤子函數(shù),是寫(xiě)出優(yōu)雅的vue前端代碼的關(guān)鍵步驟。

1.2、onMounted在vue2中的前身

1.2.1、vue2中的onMounted

        在Vue 2中,onMounted鉤子的前身實(shí)際上是mounted生命周期鉤子。在Vue 2的Options API中,生命周期鉤子是作為組件的選項(xiàng)來(lái)定義的。

        在Vue 2的組件中,mounted鉤子用于執(zhí)行那些需要在組件實(shí)例掛載到DOM之后運(yùn)行的代碼,這通常包括DOM操作、數(shù)據(jù)請(qǐng)求等。

        比如:

export default {
  data() {
    return {
      // 組件的數(shù)據(jù)
    };
  },
  mounted() {
    // 組件掛載完成后的副作用操作
    console.log('組件已掛載到DOM');
    // 可以執(zhí)行DOM操作或數(shù)據(jù)請(qǐng)求等
  },
  methods: {
    // 組件的方法
  }
};

1.2.2、Vue2與Vue3的onMounted對(duì)比

  • Vue 2:使用mounted作為組件的一個(gè)選項(xiàng)來(lái)執(zhí)行掛載后的代碼。
  • Vue 3:使用onMounted作為Composition API的鉤子來(lái)執(zhí)行掛載后的代碼。

        在Vue 3中,onMounted是Composition API的一部分,它提供了更靈活的方式來(lái)組織組件的邏輯。Vue 3的onMounted與Vue 2的mounted在功能上相似,都是在組件掛載完成后執(zhí)行,但onMounted作為Composition API的一部分,可以更好地與其它Composition API一起使用,提供更細(xì)粒度的控制和更好的組合性。

1.3、vue3中onMounted的用法

1.3.1、基礎(chǔ)用法

        這個(gè)沒(méi)什么可說(shuō)的,和watch、interval語(yǔ)法結(jié)構(gòu)一樣。

import { onMounted, ref } from 'vue';
export default {
  setup() {
    const count = ref(0);
    onMounted(() => {
      // 在這里可以執(zhí)行DOM操作或數(shù)據(jù)請(qǐng)求
      console.log('組件已掛載');
    });
    // 也可以返回一個(gè)函數(shù)進(jìn)行清理
    return {
      count
    };
  }
};

1.3.2、順序執(zhí)行異步操作

        onMounted 也常用于執(zhí)行順序異步操作,如發(fā)起網(wǎng)絡(luò)請(qǐng)求。

import { onMounted, ref } from 'vue';
import axios from 'axios';
export default {
  setup() {
    const data = ref(null);
    onMounted(async () => {
      try {
        const response = await axios.get('https://api.example.com/data');
        data.value = response.data;
        const response2 = await axios.get('https://api.example.com/data2');
        data.value2 = response2.data;
        const response3 = await axios.get('https://api.example.com/data3');
        data.value3 = response3.data;
        const response4 = await axios.get('https://api.example.com/data4');
        data.value4 = response4.data;
        // ...更多的異步操作
      } catch (error) {
        console.error('請(qǐng)求錯(cuò)誤:', error);
      }
    });
    return {
      data
    };
  }
};

1.3.3、并行執(zhí)行多個(gè)異步操作

        onMounted 也常用于執(zhí)行并行異步操作,也可以發(fā)起網(wǎng)絡(luò)請(qǐng)求。但據(jù)我實(shí)際使用的經(jīng)歷來(lái)看,異步操作能在首屏加載、大量圖片等資源加載時(shí)發(fā)揮不錯(cuò)的作用。

import { ref, onMounted } from 'vue';
import axios from 'axios';
export default {
  setup() {
    // 聲明響應(yīng)式數(shù)據(jù)引用
    const data = ref(null);
    const data2 = ref(null);
    const data3 = ref(null);
    const data4 = ref(null);
    onMounted(async () => {
      // 使用Promise.all來(lái)處理并發(fā)的axios請(qǐng)求
      await Promise.all([
        axios.get('https://api.example.com/data'),
        axios.get('https://api.example.com/data2'),
        axios.get('https://api.example.com/data3'),
        axios.get('https://api.example.com/data4')
      ]).then(responses => {
        // 所有請(qǐng)求成功完成后,更新響應(yīng)式數(shù)據(jù)
        data.value = responses[0].data;
        data2.value = responses[1].data;
        data3.value = responses[2].data;
        data4.value = responses[3].data;
        // 這里可以放置所有異步任務(wù)完成后的代碼...
      }).catch(error => {
        // 處理請(qǐng)求中出現(xiàn)的任何錯(cuò)誤
        console.error('請(qǐng)求錯(cuò)誤:', error);
      });
    });
    // 返回響應(yīng)式狀態(tài)供模板或其他Composition API使用
    return {
      data,
      data2,
      data3,
      data4
    };
  }
};

1.3.4、執(zhí)行一次性副作用

        如果你需要執(zhí)行一次性的副作用(side effect),onMounted 是一個(gè)理想的地方。

        "副作用"(side effect)是指函數(shù)在執(zhí)行時(shí)除了返回值之外對(duì)外部環(huán)境產(chǎn)生的影響。這些影響可能包括但不限于:

  • 修改全局變量:改變?cè)诤瘮?shù)外部定義的變量的值。
  • 執(zhí)行I/O操作:如讀寫(xiě)文件、網(wǎng)絡(luò)請(qǐng)求、控制臺(tái)日志輸出等。
  • 修改外部對(duì)象或數(shù)組:影響傳入函數(shù)的參數(shù)對(duì)象或數(shù)組的狀態(tài)。
  • 觸發(fā)事件:如點(diǎn)擊事件、網(wǎng)絡(luò)事件等。
  • 定時(shí)器設(shè)置:設(shè)置 setTimeout 或 setInterval。

        這里是利用onMounted鉤子函數(shù)在組件實(shí)例被成功掛載后調(diào)用的時(shí)序特性,這個(gè)組件實(shí)例已經(jīng)掛載,頁(yè)面首次渲染的時(shí)機(jī)。在這個(gè)階段可以執(zhí)行很多操作。

import { onMounted } from 'vue';
export default {
  setup() {
    onMounted(() => {
      // 執(zhí)行一次性副作用
      console.log('這是一個(gè)一次性副作用');
    });
    return {};
  }
};

1.3.5、清理工作(較少用)

        onMounted 提供的函數(shù)可以用于注冊(cè)清理工作,這在處理定時(shí)器或監(jiān)聽(tīng)器時(shí)非常有用。不過(guò)在onMounted清理的比較少,我見(jiàn)到的在onBeforeUnmount鉤子函數(shù)清理定時(shí)器、監(jiān)聽(tīng)器的比較多。

import { onMounted, ref } from 'vue';
export default {
  setup() {
    const count = ref(0);
    const intervalId = setInterval(() => {
      count.value++;
    }, 1000);
    // 注冊(cè)清理工作
    const cleanup = onMounted(() => {
      return () => {
        clearInterval(intervalId);
        console.log('定時(shí)器已清理');
      };
    });
    return {
      count,
      cleanup
    };
  }
};

1.3.6、組合使用(特定情況用)

        onMounted 可以與Vue 3的其他Composition API一起使用,以實(shí)現(xiàn)復(fù)雜的邏輯。這里主要是改變了watch的啟動(dòng)時(shí)機(jī),本來(lái)是在setup階段啟動(dòng)watch偵聽(tīng)器,但是這樣寫(xiě)就變成了在onMounted階段啟動(dòng)偵聽(tīng)器。

import { onMounted, ref, watch } from 'vue';
export default {
  setup() {
    const data = ref(null);
    onMounted(() => {
      // 可以組合使用其他Composition API
      watch(data, (newValue, oldValue) => {
        console.log(`數(shù)據(jù)從 ${oldValue} 變更為 ${newValue}`);
      });
    });
    // 模擬數(shù)據(jù)變化
    setTimeout(() => {
      data.value = { name: '新數(shù)據(jù)' };
    }, 2000);
    return {
      data
    };
  }
};

1.3.7、直接將封裝好的函數(shù)傳遞給onMounted鉤子函數(shù)調(diào)用

        Vue3中onMounted可以重復(fù)使用,多次使用,并不是像vue2那樣要寫(xiě)在某一個(gè)對(duì)象里面。但一般不推薦多次使用,這相當(dāng)于多個(gè)onMounted異步執(zhí)行操作,分散地寫(xiě)只會(huì)降低long terms的可維護(hù)性,降低可讀性,哪怕是為了迎合和充分利用composition API的特點(diǎn),我也覺(jué)得弊大于利。

function task1() {
  // 初始化任務(wù)1
}
function task2() {
  // 初始化任務(wù)2
}
onMounted(task1);
onMounted(task2);

二、總結(jié)

        onMounted作為vue3中最常用的鉤子函數(shù)之一,能夠靈活、隨心應(yīng)手的使用是每個(gè)Vue開(kāi)發(fā)者的必修課,同時(shí)根據(jù)其不同寫(xiě)法的特性,來(lái)選擇最合適最有利于維護(hù)的寫(xiě)法。

到此這篇關(guān)于如何使用Vue3的onMounted鉤子函數(shù)及vue3中onMounted的用法詳解的文章就介紹到這了,更多相關(guān)Vue3 onMounted鉤子函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用vue實(shí)現(xiàn)簡(jiǎn)單鍵盤(pán)的示例(支持移動(dòng)端和pc端)

    使用vue實(shí)現(xiàn)簡(jiǎn)單鍵盤(pán)的示例(支持移動(dòng)端和pc端)

    這篇文章主要介紹了使用vue實(shí)現(xiàn)簡(jiǎn)單鍵盤(pán)的示例(支持移動(dòng)端和pc端),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • Mint UI組件庫(kù)CheckList使用及踩坑總結(jié)

    Mint UI組件庫(kù)CheckList使用及踩坑總結(jié)

    這篇文章主要介紹了Mint UI組件庫(kù)CheckList使用及踩坑總結(jié),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • vue利用openlayers加載天地圖和高德地圖

    vue利用openlayers加載天地圖和高德地圖

    這篇文章主要介紹了?vue利用openlayers加載天地圖和高德地圖,下文章主要由兩部分完成openlayers加載天地圖和加載高德地圖,下面來(lái)看看詳細(xì)內(nèi)容吧,需要的朋友可以參考一下,希望對(duì)大家有所幫助
    2021-11-11
  • vue使用el-select下拉框匹配不到值的問(wèn)題及解決

    vue使用el-select下拉框匹配不到值的問(wèn)題及解決

    這篇文章主要介紹了vue使用el-select下拉框匹配不到值的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Vue使用三種方法刷新頁(yè)面

    Vue使用三種方法刷新頁(yè)面

    這篇文章說(shuō)明了如何使用Vue去刷新當(dāng)前頁(yè)面的多種方法實(shí)例,有完成的代碼提供參考,希望對(duì)你有所幫助
    2021-06-06
  • vue中對(duì)監(jiān)聽(tīng)esc事件和退出全屏問(wèn)題的解決方案

    vue中對(duì)監(jiān)聽(tīng)esc事件和退出全屏問(wèn)題的解決方案

    這篇文章主要介紹了vue中對(duì)監(jiān)聽(tīng)esc事件和退出全屏問(wèn)題的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • 使用elementUI實(shí)現(xiàn)將圖片上傳到本地的示例

    使用elementUI實(shí)現(xiàn)將圖片上傳到本地的示例

    今天小編就為大家分享一篇使用elementUI實(shí)現(xiàn)將圖片上傳到本地的示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • 詳解vue后臺(tái)系統(tǒng)登錄態(tài)管理

    詳解vue后臺(tái)系統(tǒng)登錄態(tài)管理

    這篇文章主要介紹了vue后臺(tái)系統(tǒng)登錄管理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 關(guān)于vue中api統(tǒng)一管理的那些事

    關(guān)于vue中api統(tǒng)一管理的那些事

    最近在學(xué)習(xí)Vue教程,下面這篇文章主要給大家介紹了關(guān)于vue中api統(tǒng)一管理的那些事,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-04-04
  • Vue3監(jiān)聽(tīng)屬性與Computed的區(qū)別詳解

    Vue3監(jiān)聽(tīng)屬性與Computed的區(qū)別詳解

    在 Vue 3 中,watch 和 computed 都是非常重要的概念,它們都可以用于觀察和響應(yīng)數(shù)據(jù)的變化,但在使用場(chǎng)景和原理上存在明顯的區(qū)別,本文將詳細(xì)解析 Vue 3 中監(jiān)聽(tīng)屬性 (watch) 和計(jì)算屬性 (computed) 的區(qū)別,需要的朋友可以參考下
    2024-02-02

最新評(píng)論