午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術(shù)文章
文章詳情頁

vue中keep-alive、activated的探討和使用詳解

瀏覽:21日期:2022-12-28 14:36:34

在修改公司的一個項(xiàng)目的時候發(fā)現(xiàn)了activated這個東西,一直覺得很疑惑,之前也沒怎么用過啊!官網(wǎng)的生命周期那也沒說過這東西啊!生命周期不就create mount update 和destory這幾個東東么,怎么多了個activate出來。

百思不得其解,于是去問了下度娘和查了下文檔!恍然大悟,原來這東東是結(jié)合keep-alive這東東使用的,下面順便記錄一下。

keep-alive

<keep-alive>包裹動態(tài)組件的時候,會緩存不活動的組件實(shí)例,而不是摧毀他們。其是一個抽象的組件,自身不會渲染一個DOM元素,也不會出現(xiàn)在父組件鏈中。

說白了被<keep-alive>包裹的組件其會被緩存

廢話不多說直接上例子.

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

<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>

代碼不用解釋了吧,就是點(diǎn)擊按鈕在ul動態(tài)添加一個li元素。

接著我們在路由中注冊一下,再回到APP.vue中修改一下配置

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

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

vue中keep-alive、activated的探討和使用詳解

如果是這樣的話所有的頁面都被緩存了,一些需要重新加載不需要緩存的我們可以通過v-for來實(shí)現(xiàn)。當(dāng)然我們可以在路由中設(shè)置一個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)說其是在服務(wù)器端渲染期間不被調(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í)行情況。我們可以看到

vue中keep-alive、activated的探討和使用詳解

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

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

vue中keep-alive、activated的探討和使用詳解

組件1中只執(zhí)行activated鉤子鉤子函數(shù),而組件2則把創(chuàng)建和掛載的鉤子函數(shù)都執(zhí)行了。

這就是緩存的原因,components其對組件進(jìn)行了緩存所以并不會再一次執(zhí)行創(chuàng)建和掛載。

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

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

以上這篇vue中keep-alive、activated的探討和使用詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 爱爱短视频 | 精品久久不卡 | 欧美一级视频免费观看 | 大香伊人久久 | 午夜视频网站 | 日韩乱码一区二区 | 国产成人一级片 | 最新av片 | 国产又粗又猛又爽又黄 | 亚洲国产日韩在线 | 中文字幕精品一区久久久久 | 国产精品15p | 午夜在线观看影院 | 精品国产一区二区三区久久久蜜月 | 在线不卡日韩 | 中文字幕亚洲天堂 | 免费91 | www.亚洲激情 | 毛片高清 | 亚洲五月婷婷 | 中文字幕精品三级久久久 | 国产精品99久久久久 | 在线看日韩av | 福利资源在线 | 鲁大师影院中文字幕 | 天天躁日日躁aaaaxxxx | 中国精品毛片 | 天堂在线视频免费 | 日本欧美一区二区 | 免费在线观看av网站 | 最新不卡av| 九九综合| 色播久久 | 中文字幕中出 | 国产精品每日更新 | 生活一级片 | 日女人的逼| 中文字幕第二区 | 欧美极品在线视频 | 亚洲精品久久久久久久久久久久久 | 久热精品视频在线 |