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

解決vue單頁面 回退頁面 keeplive 緩存問題

 更新時間:2020年07月22日 10:56:13   作者:去他喵嗚  
這篇文章主要介紹了解決vue單頁面 回退頁面 keeplive 緩存問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

場景:項目中遇到 vue 點(diǎn)擊回退 從A頁跳到B頁,緩存A頁,當(dāng)B頁狀態(tài)修改再次返回A時,A頁查詢條件緩存不刷新,列表刷新

A頁:

B頁:

解決方法:

利用keep-alive 緩存需要緩存的頁面

1.在app.vue中改寫router-view

<template>
 <div id="app">
   <keep-alive>
    <router-view v-if="$route.meta.keepAlive">
      <!-- 這里是會被緩存的視圖組件,比如 page1,page2 -->
    </router-view>
  </keep-alive>
  <router-view v-if="!$route.meta.keepAlive">
    <!-- 這里是不被緩存的視圖組件,比如 page3 -->
  </router-view>
 </div>
</template>

2.在router/index.js中添加路由元信息,設(shè)置需要緩存的頁面

keepAlive:設(shè)置需要緩存的頁面

isBack:通過beforeRouteEnter這個鉤子函數(shù)中的from參數(shù)判斷是從哪個頁面過來的,這個參數(shù)執(zhí)行時,組件實例還沒創(chuàng)建,不能在data中定義變量。所以我們可以在路由中定義一個變量isBack,用來判斷。

{
  path: '/trade',
  name: 'trade',
  component: () => import( /* webpackChunkName: "about" */ '@/views/trade.vue'),
  meta: {
   title:'trade.tradeTitle',
   keepAlive: true, // 此組件需要被緩存
   isBack:false, //用于判斷上一個頁面是哪個
  }
 },
 {
  path: '/detail/:id',
  name: 'detail',
  component: () => import( /* webpackChunkName: "about" */ '@/views/detail.vue'),
  meta: {
   title:'trade.detailTitle',
   keepAlive: false,
   isBack:false,//用于判斷上一個頁面是哪個
  }
 },

鉤子函數(shù)的執(zhí)行順序:

不使用keep-alive

beforeRouteEnter --> created --> mounted --> destroyed

使用keep-alive

beforeRouteEnter --> created --> mounted --> activated --> deactivated

再次進(jìn)入緩存的頁面,只會觸發(fā)beforeRouteEnter -->activated --> deactivated 。created和mounted不會再執(zhí)行。我們可以利用不同的鉤子函數(shù),做不同的事。務(wù)必理解上述鉤子函數(shù)的執(zhí)行時機(jī)和執(zhí)行順序,本教程的核心就依賴于此鉤子函數(shù)

activated和deactivated是使用keep-alive后,vue中比較重要的兩個鉤子函數(shù),建議詳細(xì)了解下。

在A頁面中通過beforeRouteEnter這個鉤子函數(shù)中判斷是從哪個頁面過來的

 beforeRouteLeave(to, from, next) {
 // 路由導(dǎo)航鉤子,此時還不能獲取組件實例 `this`,所以無法在data中定義變量(利用vm除外)
   // 參考 https://router.vuejs.org/zh-cn/advanced/navigation-guards.html
   // 所以,利用路由元信息中的meta字段設(shè)置變量,方便在各個位置獲取。這就是為什么在meta中定義isBack
   // 參考 https://router.vuejs.org/zh-cn/advanced/meta.html
  if (from.path === '/detail'){
   //判斷是從哪個路由過來的,
    //如果是B頁面即detail頁面過來的,表明當(dāng)前頁面不需要刷新獲取新數(shù)據(jù),直接用之前緩存的數(shù)據(jù)即可
   to.meta.isBack = true;
  }else{
   to.meta.isBack = false;
  }
  next();
 },

data中定義變量isFirstEnter用來判斷是否第一次進(jìn)入,或是否刷新了頁面,默認(rèn)false

 data() {
  return {
   isFirstEnter:false,
  };
 },

created中把isFirstEnter變?yōu)閠rue,說明是第一次進(jìn)入或刷新了頁面

 created() {
   this.isFirstEnter=true;
   // 只有第一次進(jìn)入或者刷新頁面后才會執(zhí)行此鉤子函數(shù)
   // 使用keep-alive后(2+次)進(jìn)入不會再執(zhí)行此鉤子函數(shù)
   this.$nextTick(() => {
   this.getLists();
  });
 },

activated中增加判斷條件

activated() {
  if(this.$route.meta.isBack || !this.isFirstEnter){
   // 如果isBack是false,表明需要獲取新數(shù)據(jù),否則就不再請求,直接使用緩存的數(shù)據(jù)
   // 如果isFirstEnter是true,表明是第一次進(jìn)入此頁面或用戶刷新了頁面,需獲取新數(shù)據(jù)
   this.tradeList=[]
   this.AjaxList = []   //把數(shù)據(jù)清空,可以稍微避免讓用戶看到之前緩存的數(shù)據(jù)
   this.pageNum = 1;
   this.$nextTick(() => {
    this.getLists();
   });
  }else{
   this.$route.meta.isBack=false
   this.isFirstEnter=false;
  }
},

以上這篇解決vue單頁面 回退頁面 keeplive 緩存問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 在vue3中使用icon圖標(biāo)的三種方案

    在vue3中使用icon圖標(biāo)的三種方案

    這篇文章主要介紹了三種使用icon的方案,分別是element-icon、svg-icon、@iconify/vue,三種方案通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • 詳解為element-ui的Select和Cascader添加彈層底部操作按鈕

    詳解為element-ui的Select和Cascader添加彈層底部操作按鈕

    這篇文章主要介紹了詳解為element-ui的Select和Cascader添加彈層底部操作按鈕,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • vue-cli 為項目設(shè)置別名的方法

    vue-cli 為項目設(shè)置別名的方法

    這篇文章主要介紹了vue-cli 為項目設(shè)置別名的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • vue router導(dǎo)航守衛(wèi)(router.beforeEach())的使用詳解

    vue router導(dǎo)航守衛(wèi)(router.beforeEach())的使用詳解

    導(dǎo)航守衛(wèi)主要用來通過跳轉(zhuǎn)或取消的方式守衛(wèi)導(dǎo)航。這篇文章主要介紹了vue-router導(dǎo)航守衛(wèi)(router.beforeEach())的使用,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • Vue3的10種組件通信方式總結(jié)

    Vue3的10種組件通信方式總結(jié)

    組件是vue.js最強(qiáng)大的功能之一,而組件實例的作用域是相互獨(dú)立的,這就意味著不同組件之間的數(shù)據(jù)無法相互引用,這篇文章主要給大家介紹了關(guān)于Vue3的10種組件通信方式的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-03-03
  • Vue項目實現(xiàn)簡單的權(quán)限控制管理功能

    Vue項目實現(xiàn)簡單的權(quán)限控制管理功能

    這篇文章主要介紹了Vue項目實現(xiàn)簡單的權(quán)限控制功能,文中給大家介紹了兩種方式進(jìn)行權(quán)限限制,本文通過實例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2019-07-07
  • element?實現(xiàn)導(dǎo)航欄收起展開功能及思路

    element?實現(xiàn)導(dǎo)航欄收起展開功能及思路

    這篇文章主要介紹了element?實現(xiàn)導(dǎo)航欄收起展開功能,實現(xiàn)思路先給 el-menu加上 :collapse="isCollapse" 屬性,這個屬性也是 element 上的一個參數(shù),意思為是否開啟折疊動畫,在 data 中定義 isCollapse ,用 true 和 false 控制展開與收起,需要的朋友可以參考下
    2023-01-01
  • Vue3+TypeScript封裝axios并進(jìn)行請求調(diào)用的實現(xiàn)

    Vue3+TypeScript封裝axios并進(jìn)行請求調(diào)用的實現(xiàn)

    這篇文章主要介紹了Vue3+TypeScript封裝axios并進(jìn)行請求調(diào)用的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Element-ui?Dialog對話框基本使用

    Element-ui?Dialog對話框基本使用

    這篇文章主要為大家介紹了Element-ui?Dialog對話框基本使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • vue更新數(shù)據(jù)卻不渲染頁面的解決

    vue更新數(shù)據(jù)卻不渲染頁面的解決

    這篇文章主要介紹了vue更新數(shù)據(jù)卻不渲染頁面的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08

最新評論