国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

vue中activated的用法

瀏覽:2日期:2022-10-13 14:01:29
keep-alive

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

我們現在創建兩個子組件conpoment1,compoment2,其內容如下

<template> <div class='wrapper'> <ul class='content'></ul> <button @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動態添加一個li元素。接著我們在路由中注冊一下,再回到APP.vue中修改一下配置

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

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

vue中activated的用法

如果是這樣的話所有的頁面都被緩存了,一些需要重新加載不需要緩存的我們可以通過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>

這時候我們回到頁面中添加子元素并切換路由就會發現只有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個組件中分別打印出其鉤子函數執行情況。我們可以看到

vue中activated的用法

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

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

vue中activated的用法

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

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

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

補充:

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

activated

類型:func

觸發時機:keep-alive組件激活時使用;

deactivated

類型:func

觸發時機:keep-alive組件停用時調用;

以上就是vue中activated的用法的詳細內容,更多關于vue activated用法的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
主站蜘蛛池模板: 国产一区亚洲二区三区 | 性生话一级国产片 | 成人久久18网站 | 亚洲精品久久久久中文 | 亚洲二区在线观看 | 福利云| 成年午夜性视频免费播放 | 性刺激久久久久久久久 | 99国产成人高清在线视频 | 免费一级毛片不卡在线播放 | 91国内视频在线观看 | 久久精品视频亚洲 | 成人午夜性a一级毛片美女 成人午夜亚洲影视在线观看 | 欧美成人影院 在线播放 | 欧美日韩另类国产 | 久久久久久九九 | 日本黄页网站在线观看 | 午夜性色福利视频在线视频 | 成人网视频在线观看免费 | 亚洲欧美日韩天堂 | 国产网站黄| 国产精品日韩欧美一区二区三区 | 欧美xxxxb| 欧洲亚洲综合一区二区三区 | 一级特黄a视频 | 91桃色成人免费 | 欧美视频精品一区二区三区 | 亚洲精品成人网久久久久久 | 亚洲成人性视频 | 国产日韩欧美精品 | 久久99国产精品 | 日本三级韩国三级在线观看a级 | 日本一本久 | 国产成人综合精品一区 | 日韩欧美在线综合网高清 | 亚洲自拍中文 | 日本高清视频免费在线观看 | 久久久久成人精品一区二区 | 国产成人精品曰本亚洲78 | 武松金莲肉体交战在线观看 | 国产综合亚洲专区在线 |