亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue路由中前進(jìn)后退的一些事兒

 更新時間:2019年05月18日 09:11:52   作者:喬巴不想說話  
這篇文章主要給大家介紹了關(guān)于vue路由中前進(jìn)后退的一些事兒,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用vue路由具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

前言

最近蒸煮在做一個獨(dú)立項(xiàng)目的時候遇到了一個小坑,特此做個爬坑紀(jì)念。

基本情景是頁面之間通過vue路由跳轉(zhuǎn),從頁面A跳轉(zhuǎn)到頁面B(在頁面B進(jìn)行對應(yīng)操作后),再從頁面B跳轉(zhuǎn)到頁面C。之后再從頁面C返回到頁面B,頁面B保留之前狀態(tài),返回頁面A,頁面B狀態(tài)不保留。(。・∀・)ノ゙嗨~感覺說的好亂。

總之就是,前進(jìn)刷新,后退不刷新(刷新是指是否重新渲染)

相信很多小伙伴都會想到用keep-alive開啟緩存頁面來實(shí)現(xiàn),鵝,蒸煮也沒例外,下面就是蒸煮的爬坑過程。

vue路由開啟keep-alive緩存頁面

keep-alive是vue官方提供的一種緩存組件實(shí)例的方法。

第一步,先改寫<router-view>的展示方式

<keep-alive>
//這是會被緩存的頁面
 <router-view v-if="$route.meta.keepAlive">
 </router-view></keep-alive>
<router-view v-if = "!$route.meta.keepAlive">
//這里是不被緩存的組件
</router-view>

第二步,在路由配置文件里,配置組件是否被緩存

routes:[
 {  path: '/', 
   name: 'Index', 
   component: Index,  
   meta:{ 
    title:"博物館",  
    keepAlive:false//不緩存 
   } 
   }, 
   { 
   path:'/searchMain', 
   name:'SearchMain', 
   component:SearchMain, 
   meta:{ 
    title:"搜索", 
    keepAlive:true,//緩存 
     } 
   },
   { 
   path:'/collectionDetails', 
   name:'CollectionDetails', 
   component:CollectionDetails, 
   meta:{  
    title:"藏品詳情", 
    keepAlive:false,//不緩存 
    } 
   }]

這樣的話無論什么時候,緩存的組件一直會被緩存

第三步,根據(jù)路由鉤子來改變緩存組件的狀態(tài)

beforeRouteLeave(to, from, next) { 
  if(to.path="首頁"){
   from.meta.keepAlive =false;
  }else if(to.path="詳情頁"){
  from.meta.keepAlive = true;
  } // 跳轉(zhuǎn)到 首頁時,不緩存,跳轉(zhuǎn)到詳情頁時緩存(就是不刷新) 
  next();
  }
這種行嗎?行嗎?行嗎?不行??!因?yàn)榈谝淮蔚臅r候確實(shí)會成功,可是退出去以后就gg了,
因?yàn)閗eepAlive已經(jīng)變成了false,第二次就不會緩存。那么第一個頁面加下面代碼,讓他進(jìn)入的時候
 beforeRouteLeave(to, from, next) { 
  if(to.path=="/searchMain"){ 
  to.meta.keepAlive =true;  
  } 
  next(true); 
 return; 
},

實(shí)踐證明,搜索界面的數(shù)據(jù)一直是第一次緩存過的數(shù)據(jù)。

二,為了解決這個問題,蒸煮想起了keep-alive組件相關(guān)的兩個鉤子函數(shù)。

activated:緩存的組件再次進(jìn)入時觸發(fā);

deactivated:緩存的組件離開時會觸發(fā);

第一次進(jìn)入keep-alive組件時,其生命周期執(zhí)行順序:

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

非首次進(jìn)入時,其生命周期執(zhí)行順序

beforeRouteEnter ->activated ->deactivated

第二次進(jìn)入的時候vue組件的生命周期函數(shù)都沒有執(zhí)行,說明緩存組件也無法銷毀。更無法更新。

解決方法

 activated() {
 if(!this.$route.meta.isBack) {
  // 如果isBack是false,表明需要獲取新數(shù)據(jù),否則就不再請求,直接使用緩存的數(shù)據(jù)  this.getData(); // ajax獲取數(shù)據(jù)方法
 }
 // 恢復(fù)成默認(rèn)的false,避免isBack一直是true,導(dǎo)致下次無法獲取數(shù)據(jù)
 this.$route.meta.isBack = false
},

但素,重新?lián)Q取數(shù)據(jù),之前保存在data里的數(shù)據(jù)并沒有變,感覺還是不太徹底!

終極解決方案

最后終于到答案的最后一步啦那

就是動態(tài)給要緩存的路由組件添加key值啦~

<keep-alive>
   <router-view v-if="$route.meta.keepAlive" :key='key'></router-view>
</keep-alive>
   <router-view v-if="!$route.meta.keepAlive" :key='key'></router-view>

在vuex中有條件改變key的值

beforeRouteLeave(to,from,next){
 if(to.path=="/"){
  this.$store.commit("UPDATE_KEY",this.$route.name!==undefined?this.$route.name+
  +new Date():this.$route+ +new Date());
 }
}

這樣的話就會有一個很重要的問題,這些緩存過的組件,都是在內(nèi)存中的,如果一直操作,內(nèi)存堆積越來越大,導(dǎo)致系統(tǒng)卡頓。所以離開時就銷毀吧

手動觸發(fā)銷毀

beforeRouteLeave(to,from,next){
 if(to.path=="/"){
  this.$store.commit("UPDATE_KEY",this.$route.name!==undefined?this.$route.name+ +new Date():this.$route+ +new Date());
     this.$destroy();//銷毀吧
}

結(jié)語:寫完了,希望能夠供大家參考哦!

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。

相關(guān)文章

  • vue 組件中使用 transition 和 transition-group實(shí)現(xiàn)過渡動畫

    vue 組件中使用 transition 和 transition-group實(shí)現(xiàn)過渡動畫

    本文給大家分享一下vue 組件中使用 transition 和 transition-group 設(shè)置過渡動畫,總結(jié)來說可分為分為 name 版, js 鉤子操作類名版, js 鉤子操作行內(nèi)樣式版,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友參考下吧
    2019-07-07
  • vue如何引用其他組件(css和js)

    vue如何引用其他組件(css和js)

    本篇文章主要介紹了vue如何引用其他組件(css和js) ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • vue路由劃分模塊并自動引入方式

    vue路由劃分模塊并自動引入方式

    這篇文章主要介紹了vue路由劃分模塊并自動引入方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 從零寫vue日歷組件

    從零寫vue日歷組件

    最近做項(xiàng)目遇到一個需求,需要制作一個定制化的日歷組件,本文主要介紹了從零寫vue日歷組件,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue服務(wù)端渲染添加緩存的方法

    vue服務(wù)端渲染添加緩存的方法

    vue服務(wù)區(qū)緩存分為頁面緩存、組建緩存和接口緩存,本文通過實(shí)例代碼逐一給大家介紹,本文重點(diǎn)給大家介紹vue服務(wù)端渲染添加緩存的方法,感興趣的朋友跟隨小編一起看看吧
    2018-09-09
  • 深入了解Vue3組件傳值方式

    深入了解Vue3組件傳值方式

    學(xué)習(xí)過?vue2?的寶子們肯定知道,組件傳值是?vue?項(xiàng)目開發(fā)過程中必不可少的功能場景,在?vue2?里面有很多傳值的方式。今天就來和大家講講Vue3的組件傳值方式,需要的可以參考一下
    2022-07-07
  • vue.js整合vux中的上拉加載下拉刷新實(shí)例教程

    vue.js整合vux中的上拉加載下拉刷新實(shí)例教程

    這篇文章主要給大家介紹了關(guān)于vue.js整合vux中上拉加載下拉刷新的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-01-01
  • Vue表格首列相同數(shù)據(jù)合并實(shí)現(xiàn)方法

    Vue表格首列相同數(shù)據(jù)合并實(shí)現(xiàn)方法

    這篇文章主要介紹了Vue實(shí)現(xiàn)表格首列相同數(shù)據(jù)合并的方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • vue3動態(tài)加載對話框的方法實(shí)例

    vue3動態(tài)加載對話框的方法實(shí)例

    對話框是很常用的組件,在很多地方都會用到,下面這篇文章主要給大家介紹了關(guān)于vue3動態(tài)加載對話框的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-03-03
  • vue組件中的數(shù)據(jù)傳遞方法

    vue組件中的數(shù)據(jù)傳遞方法

    這篇文章主要介紹了vue組件中的數(shù)據(jù)傳遞方法,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-05-05

最新評論