色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

vue中activated的用法

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

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

我們現(xiàn)在創(chuàng)建兩個(gè)子組件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動(dòng)態(tài)添加一個(gè)li元素。接著我們?cè)诼酚芍凶?cè)一下,再回到APP.vue中修改一下配置

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

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

vue中activated的用法

如果是這樣的話所有的頁面都被緩存了,一些需要重新加載不需要緩存的我們可以通過v-for來實(shí)現(xiàn)。當(dāng)然我們可以在路由中設(shè)置一個(gè)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>

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

activated

先說下這個(gè)生命周期鉤子,官網(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ù)'); }

我們?cè)?個(gè)組件中分別打印出其鉤子函數(shù)執(zhí)行情況。我們可以看到

vue中activated的用法

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

當(dāng)我們?cè)偾袚Q一次路由的時(shí)候又發(fā)現(xiàn)了神奇的地方

vue中activated的用法

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

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

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

補(bǔ)充:

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

activated

類型:func

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

deactivated

類型:func

觸發(fā)時(shí)機(jī):keep-alive組件停用時(shí)調(diào)用;

以上就是vue中activated的用法的詳細(xì)內(nèi)容,更多關(guān)于vue activated用法的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 91成人在线播放 | 亚洲最新视频在线观看 | 日韩福利视频精品专区 | 欧美午夜精品久久久久久黑人 | 国产亚洲精品精品国产亚洲综合 | 中日韩一级片 | 久久久久久久国产高清 | 日本亚洲成高清一区二区三区 | 国产精品久久久久影院色老大 | 欧美一级毛片特黄黄 | 日产国产精品久久久久久 | 国产在线观看成人免费视频 | 99久久精品久久久久久婷婷 | www.99精品 | 国产午夜永久福利视频在线观看 | 在线播放一区二区精品产 | 91在线精品亚洲一区二区 | 一级片一区 | 国产精品久久大陆 | 91免费永久在线地址 | 99视频有精品视频免费观看 | 男女乱淫免费视频 | 91免费看片 | 91亚洲精品在看在线观看高清 | 精品免费久久 | 亚洲狠狠ady亚洲精品大秀 | 加勒比久久综合 | 99久久精彩视频 | 99精品视频免费在线观看 | 97在线视频免费观看费观看 | 黄色毛片免费在线观看 | 免费99视频 | 亚洲性视频在线 | 精品一区二区三区在线观看 | 午夜在线成人 | 国产日韩在线看 | 婷婷色九月综合激情丁香 | 综合久久一区二区三区 | 最新理论三级中文在线观看 | 国内亚州视频在线观看 | 日本九九视频 |