vue中keep-alive、activated的探討和使用詳解
在修改公司的一個項目的時候發(fā)現(xiàn)了activated這個東西,一直覺得很疑惑,之前也沒怎么用過??!官網(wǎng)的生命周期那也沒說過這東西?。∩芷诓痪蚦reate mount update 和destory這幾個東東么,怎么多了個activate出來。
百思不得其解,于是去問了下度娘和查了下文檔!恍然大悟,原來這東東是結合keep-alive這東東使用的,下面順便記錄一下。
keep-alive
<keep-alive>包裹動態(tài)組件的時候,會緩存不活動的組件實例,而不是摧毀他們。其是一個抽象的組件,自身不會渲染一個DOM元素,也不會出現(xiàn)在父組件鏈中。
說白了被<keep-alive>包裹的組件其會被緩存
廢話不多說直接上例子.
我們現(xiàn)在創(chuàng)建兩個子組件conpoment1,compoment2,其內(nèi)容如下
<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ā)現(xiàn),當我們切換路由的時候,我們之前添加的子元素還回保存在那里
如果是這樣的話所有的頁面都被緩存了,一些需要重新加載不需要緩存的我們可以通過v-for來實現(xiàn)。當然我們可以在路由中設置一個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ā)現(xiàn)只有components1中的組件有緩存。
activated
先說下這個生命周期鉤子,官網(wǎng)說其是在服務器端渲染期間不被調(diào)用,
說白了其就是在掛載后和更新前被調(diào)用的。但如果該組件中沒有使用緩存,也就是沒有被<keep-alive>包裹的話,activated是不起作用的。我們直接來試一下就知道了。
//components1中 created() { console.log("1激活created鉤子函數(shù)"); }, activated() { console.log("1激活activated鉤子函數(shù)"); }, mounted() { console.log("1激活mounted鉤子函數(shù)"); } //components2中 created() { console.log("2激活created鉤子函數(shù)"); }, activated() { console.log("2激活activated鉤子函數(shù)"); }, mounted() { console.log("2激活mounted鉤子函數(shù)"); }
我們在2個組件中分別打印出其鉤子函數(shù)執(zhí)行情況。我們可以看到
在執(zhí)行components1時候其是執(zhí)行了activated鉤子函數(shù)的,而components2則沒有,因為components2并沒有被<keep-alive>包裹,所以其并不會激活該鉤子函數(shù)。
當我們再切換一次路由的時候又發(fā)現(xiàn)了神奇的地方
組件1中只執(zhí)行activated鉤子鉤子函數(shù),而組件2則把創(chuàng)建和掛載的鉤子函數(shù)都執(zhí)行了。
這就是緩存的原因,components其對組件進行了緩存所以并不會再一次執(zhí)行創(chuàng)建和掛載。
簡單的說activated()函數(shù)就是一個頁面激活后的鉤子函數(shù),一進入頁面就觸發(fā);
所以當我們運用了組件緩存時,如果想每次切換都發(fā)送一次請求的話,需要把請求函數(shù)寫在activated中,而寫在created或mounted中其只會在首次加載該組件的時候起作用。
以上這篇vue中keep-alive、activated的探討和使用詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Vue?打包優(yōu)化之externals抽離公共的第三方庫詳解
這篇文章主要為大家介紹了Vue?打包優(yōu)化之externals抽離公共的第三方庫詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪<BR>2023-06-06如何配置vue.config.js 處理static文件夾下的靜態(tài)文件
這篇文章主要介紹了如何配置vue.config.js 處理static文件夾下的靜態(tài)文件,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-06-06Vue3+cesium環(huán)境搭建的實現(xiàn)示例
本文主要介紹了Vue3+cesium環(huán)境搭建的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-08-08關于Elementui中toggleRowSelection()方法實現(xiàn)分頁切換時記錄之前選中的狀態(tài)
這篇文章主要介紹了關于Elementui中toggleRowSelection()方法實現(xiàn)分頁切換時記錄之前選中的狀態(tài),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03