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

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

 更新時(shí)間:2020年07月26日 10:34:54   作者:0斌果0  
這篇文章主要介紹了vue中keep-alive、activated的探討和使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

在修改公司的一個(gè)項(xiàng)目的時(shí)候發(fā)現(xiàn)了activated這個(gè)東西,一直覺(jué)得很疑惑,之前也沒(méi)怎么用過(guò)?。」倬W(wǎng)的生命周期那也沒(méi)說(shuō)過(guò)這東西?。∩芷诓痪蚦reate mount update 和destory這幾個(gè)東東么,怎么多了個(gè)activate出來(lái)。

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

keep-alive

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

說(shuō)白了被<keep-alive>包裹的組件其會(huì)被緩存

廢話不多說(shuō)直接上例子.

我們現(xiàn)在創(chuàng)建兩個(gè)子組件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>

代碼不用解釋了吧,就是點(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í)候,我們之前添加的子元素還回保存在那里

如果是這樣的話所有的頁(yè)面都被緩存了,一些需要重新加載不需要緩存的我們可以通過(guò)v-for來(lái)實(shí)現(xiàn)。當(dāng)然我們可以在路由中設(shè)置一個(gè)key值來(lái)判斷組件是否需要緩存,就像下面這樣

//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í)候我們回到頁(yè)面中添加子元素并切換路由就會(huì)發(fā)現(xiàn)只有components1中的組件有緩存。

activated

先說(shuō)下這個(gè)生命周期鉤子,官網(wǎng)說(shuō)其是在服務(wù)器端渲染期間不被調(diào)用,

說(shuō)白了其就是在掛載后和更新前被調(diào)用的。但如果該組件中沒(méi)有使用緩存,也就是沒(méi)有被<keep-alive>包裹的話,activated是不起作用的。我們直接來(lái)試一下就知道了。

//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í)行情況。我們可以看到

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

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

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

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

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

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

以上這篇vue中keep-alive、activated的探討和使用詳解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue項(xiàng)目打包后怎樣優(yōu)雅的解決跨域

    vue項(xiàng)目打包后怎樣優(yōu)雅的解決跨域

    這篇文章主要介紹了vue項(xiàng)目打包后怎樣優(yōu)雅的解決跨域,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • vue封裝動(dòng)態(tài)表格方式詳解

    vue封裝動(dòng)態(tài)表格方式詳解

    這篇文章主要為大家介紹了vue封裝動(dòng)態(tài)表格方式示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • Vue?打包優(yōu)化之externals抽離公共的第三方庫(kù)詳解

    Vue?打包優(yōu)化之externals抽離公共的第三方庫(kù)詳解

    這篇文章主要為大家介紹了Vue?打包優(yōu)化之externals抽離公共的第三方庫(kù)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪<BR>
    2023-06-06
  • 如何配置vue.config.js 處理static文件夾下的靜態(tài)文件

    如何配置vue.config.js 處理static文件夾下的靜態(tài)文件

    這篇文章主要介紹了如何配置vue.config.js 處理static文件夾下的靜態(tài)文件,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • vue的ssr服務(wù)端渲染示例詳解

    vue的ssr服務(wù)端渲染示例詳解

    這篇文章主要給大家介紹了關(guān)于vue的ssr服務(wù)端渲染的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Vue3+cesium環(huán)境搭建的實(shí)現(xiàn)示例

    Vue3+cesium環(huán)境搭建的實(shí)現(xiàn)示例

    本文主要介紹了Vue3+cesium環(huán)境搭建的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-08-08
  • vue實(shí)現(xiàn)一個(gè)移動(dòng)端屏蔽滑動(dòng)的遮罩層實(shí)例

    vue實(shí)現(xiàn)一個(gè)移動(dòng)端屏蔽滑動(dòng)的遮罩層實(shí)例

    本篇文章主要介紹了vue實(shí)現(xiàn)一個(gè)移動(dòng)端屏蔽滑動(dòng)的遮罩層實(shí)例,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-06-06
  • 關(guān)于Elementui中toggleRowSelection()方法實(shí)現(xiàn)分頁(yè)切換時(shí)記錄之前選中的狀態(tài)

    關(guān)于Elementui中toggleRowSelection()方法實(shí)現(xiàn)分頁(yè)切換時(shí)記錄之前選中的狀態(tài)

    這篇文章主要介紹了關(guān)于Elementui中toggleRowSelection()方法實(shí)現(xiàn)分頁(yè)切換時(shí)記錄之前選中的狀態(tài),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue使用自定義指令打開dialog的實(shí)現(xiàn)方法

    Vue使用自定義指令打開dialog的實(shí)現(xiàn)方法

    在web后臺(tái)管理項(xiàng)目中,經(jīng)常要用到dialog,就vue來(lái)說(shuō),使用方式則是引入組件,注冊(cè),在template中使用,試想一下,如果我們需要在項(xiàng)目中的不同.vue文件中使用該dialog,但是又不想每次都在template中寫入組件該如何實(shí)現(xiàn)呢?本文我們介紹用指令控制dialog,需要的朋友可以參考下
    2024-07-07
  • Vue中實(shí)現(xiàn)過(guò)渡動(dòng)畫效果實(shí)例詳解

    Vue中實(shí)現(xiàn)過(guò)渡動(dòng)畫效果實(shí)例詳解

    最近在寫vue的一個(gè)項(xiàng)目要實(shí)現(xiàn)過(guò)渡的效果,雖然vue動(dòng)畫不是強(qiáng)項(xiàng),庫(kù)也多,但是基本的坑還是得踩扎實(shí),下面這篇文章主要給大家介紹了關(guān)于Vue中實(shí)現(xiàn)過(guò)渡動(dòng)畫效果的相關(guān)資料,需要的朋友可以參考下
    2022-08-08

最新評(píng)論