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

vue中activated的用法

 更新時間:2021年01月03日 09:36:16   作者:之鹿喵  
這篇文章主要介紹了vue中activated的用法,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下

keep-alive

<keep-alive>包裹動態(tài)組件的時候,會緩存不活動的組件實例,而不是摧毀他們。其是一個抽象的組件,自身不會渲染一個DOM元素,也不會出現在父組件鏈中。
說白了被<keep-alive>包裹的組件其會被緩存
廢話不多說直接上例子.

我們現在創(chuàng)建兩個子組件conpoment1,compoment2,其內容如下

<template>
 <div class="wrapper">
  <ul class="content"></ul>
  <button class="add" id="add" @click="add">添加子元素</button>
 </div>
</template>

<script>
export default {
 data() {
  return {};
 },
 methods: {
  add() {
   let ul = document.getElementsByClassName("content")[0]; 
   let li = document.createElement("li");
   li.innerHTML = "我是添加的元素";
   ul.appendChild(li);   
  }
 }
};
</script>
<style >
</style>

代碼不用解釋了吧,就是點擊按鈕在ul動態(tài)添加一個li元素。
接著我們在路由中注冊一下,再回到APP.vue中修改一下配置

<template>
 <div id="app">
  <keep-alive>
   <router-view />
  </keep-alive>
</template>

這樣我們就會發(fā)現,當我們切換路由的時候,我們之前添加的子元素還回保存在那里

如果是這樣的話所有的頁面都被緩存了,一些需要重新加載不需要緩存的我們可以通過v-for來實現。當然我們可以在路由中設置一個key值來判斷組件是否需要緩存,就像下面這樣

//index.js
{
   path: '/1',
   name: 'components1',
   component: Components1,
   meta: {
    keepAlive: true  //判斷是否緩存
   }
  },
  {
   path: '/2',
   name: 'components2',
   component: Components2,
   meta: {
     keepAlive: false
   }
  },

然后我們的App.vue中只需要判斷其keepAlive值即可

 <div id="app">
  <keep-alive>
   <router-view v-if="$route.meta.keepAlive" />
  </keep-alive>
  <router-view v-if="!$route.meta.keepAlive" />
</template>

這時候我們回到頁面中添加子元素并切換路由就會發(fā)現只有components1中的組件有緩存。

activated

先說下這個生命周期鉤子,官網說其是在服務器端渲染期間不被調用,
說白了其就是在掛載后和更新前被調用的。但如果該組件中沒有使用緩存,也就是沒有被<keep-alive>包裹的話,activated是不起作用的。我們直接來試一下就知道了。

//components1中
 created() {
  console.log("1激活created鉤子函數");
 },
 activated() {
  console.log("1激活activated鉤子函數");
 },
 mounted() {
  console.log("1激活mounted鉤子函數");
 }

//components2中
 created() {
  console.log("2激活created鉤子函數");
 },
 activated() {
  console.log("2激活activated鉤子函數");
 },
 mounted() {
  console.log("2激活mounted鉤子函數");
 }

我們在2個組件中分別打印出其鉤子函數執(zhí)行情況。我們可以看到

在執(zhí)行components1時候其是執(zhí)行了activated鉤子函數的,而components2則沒有,因為components2并沒有被<keep-alive>包裹,所以其并不會激活該鉤子函數。

當我們再切換一次路由的時候又發(fā)現了神奇的地方

組件1中只執(zhí)行activated鉤子鉤子函數,而組件2則把創(chuàng)建和掛載的鉤子函數都執(zhí)行了。
這就是緩存的原因,components其對組件進行了緩存所以并不會再一次執(zhí)行創(chuàng)建和掛載。

簡單的說activated()函數就是一個頁面激活后的鉤子函數,一進入頁面就觸發(fā);

所以當我們運用了組件緩存時,如果想每次切換都發(fā)送一次請求的話,需要把請求函數寫在activated中,而寫在created或mounted中其只會在首次加載該組件的時候起作用。

補充:

keep-alive組件除了actived,還有deactived函數鉤子

activated

類型:func

觸發(fā)時機:keep-alive組件激活時使用;

deactivated

類型:func

觸發(fā)時機:keep-alive組件停用時調用;

以上就是vue中activated的用法的詳細內容,更多關于vue activated用法的資料請關注腳本之家其它相關文章!

相關文章

  • vue實現一個簡單的Grid拖拽布局

    vue實現一個簡單的Grid拖拽布局

    這篇文章主要為大家詳細介紹了如何利用vue實現一個簡單的Grid拖拽布局,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-12-12
  • Vue跨端渲染實現多端無縫銜接

    Vue跨端渲染實現多端無縫銜接

    這篇文章主要介紹了Vue跨端渲染實現多端無縫銜接,Vue跨端渲染是一種基于Vue框架的跨平臺開發(fā)技術,能夠實現Web、iOS和Android三端的無縫銜接,提高開發(fā)效率和用戶體驗
    2023-05-05
  • vue2如何獲取上頁的url地址

    vue2如何獲取上頁的url地址

    這篇文章主要介紹了vue2如何獲取上頁的url地址問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue3使用Echarts導致tooltip失效問題及解決方法

    Vue3使用Echarts導致tooltip失效問題及解決方法

    Vue3 使用 proxy 對象代理,而 echarts 則使用了大量的全等(===), 對比失敗從而導致了bug,這篇文章主要介紹了Vue3使用Echarts導致tooltip失效問題及解決方法,需要的朋友可以參考下
    2023-08-08
  • Element?UI表單驗證規(guī)則動態(tài)失效問題的解決辦法

    Element?UI表單驗證規(guī)則動態(tài)失效問題的解決辦法

    這篇文章主要給大家介紹了關于Element?UI表單驗證規(guī)則動態(tài)失效問題的解決辦法,Element UI提供了強大的表單驗證功能,可以輕松地對表單進行驗證,需要的朋友可以參考下
    2023-09-09
  • Vue?keep-alive的實現原理分析

    Vue?keep-alive的實現原理分析

    這篇文章主要介紹了Vue?keep-alive的實現原理分析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue封裝--如何將數字轉換成萬

    Vue封裝--如何將數字轉換成萬

    這篇文章主要介紹了Vue封裝--將數字轉換成萬的實現方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • vue調用原生方法交互解讀

    vue調用原生方法交互解讀

    這篇文章主要介紹了vue調用原生方法交互,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue點擊按鈕動態(tài)創(chuàng)建與刪除組件功能

    vue點擊按鈕動態(tài)創(chuàng)建與刪除組件功能

    這篇文章主要介紹了vue點擊按鈕動態(tài)創(chuàng)建與刪除組件功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-12-12
  • vue3.0生命周期的示例代碼

    vue3.0生命周期的示例代碼

    這篇文章主要介紹了vue3.0生命周期的相關知識,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2020-09-09

最新評論