日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

vue 路由緩存 路由嵌套 路由守衛 監聽物理返回操作

瀏覽:279日期:2022-12-14 14:53:43

最近開發vue項目,遇到的一些問題,這里整合一下,看到一些博客已經有寫相關知識,然后自己再次記錄一下。

這是關于vue路由相關比較常見的問題,以后遇到相關路由的問題,會不斷更新這篇博客。

需求1:從填寫表單A頁面跳轉到B頁面,然后再從B頁面返回到A頁面,實現A頁面的所填的數據保留

一.設置路由緩存:

1.App.vue中加入<keep-alive> 具體代碼如下:

<template> <div id='app'> <!--<img src='http://www.b3g6.com/bcjs/assets/logo.png'>--> <keep-alive> <router-view v-if='$route.meta.keepAlive'> <!-- 這里是會被緩存的視圖組件A --> </router-view> </keep-alive> <router-view v-if='!$route.meta.keepAlive'> <!-- 這里是不被緩存的視圖組件B --> </router-view> </div></template>

2.在路由配置文件index.js里面增加meta標簽,代碼如下:

export default new Router({ routes: [ { path: ’/’, name: ’Initinfo’, component: Initinfo }, { path: ’/B’, name:’B’, component: CredentialsDetails, meta:{keepAlive:false} }, { path: ’/A’, name:’A’, component: ASeal, meta:{keepAlive:true} } ]})

ok,做到這里,就能實現以上需求1。

需求2:在需求1基礎上,增加一個需求就是,緩存A表單頁面滾動位置,代碼如下:

export default new Router({ //使用keep-alive后,可能存在滾動條問題的解決問題 mode:’hash’,//默認是hash模式 且有history scrollBehavior(to,from,savePosition) { // 在點擊瀏覽器的“前進/后退”,或者切換導航的時候觸發。 console.log(to) // to:要進入的目標路由對象,到哪里去 console.log(from) // from:離開的路由對象,哪里來 console.log(savePosition) // savePosition:會記錄滾動條的坐標,點擊前進/后退的時候記錄值{x:?,y:?} if(savePosition){ return savePosition; }else{ return { x: 0, y: 0 } } }, routes: [ { path: ’/’, name: ’Initinfo’, component: Initinfo }, { path: ’/B’, name:’B’, component: CredentialsDetails, meta:{keepAlive:false} }, { path: ’/A’, name:’A’, component: ASeal, meta:{keepAlive:true} } ]})

需求3:

1.默認顯示 A

2. B跳到 A,A 不刷新

3. C跳到 A,A 刷新

https://router.vuejs.org/zh/guide/advanced/navigation-guards.html

以上是路由守衛官網,可以參考,下面介紹兩個守衛:beforeRouteLeave,beforeRouteEnter

1.在路由的index.js文件,和以上路由一樣,設置A頁面的meta屬性,代碼如下:

{ path: ’/A’, name:’A’, component: ASeal, meta:{keepAlive:true} }

2. 在B組件設置 beforeRouteLeave:代碼如下:

export default { beforeRouteLeave(to, from, next) { console.log(to); console.log(from) // 設置下一個路由的 meta to.meta.keepAlive = true; // 讓 A 緩存,即不刷新 next();//確保要調用 next 方法,否則鉤子就不會被 resolved }};

3.在C組件設置 beforeRouteLeave:代碼如下:

export default { beforeRouteLeave(to, from, next) { console.log(to); console.log(from) // 設置下一個路由的 meta to.meta.keepAlive = false; // 讓 A不緩存,即刷新 next();//確保要調用 next 方法,否則鉤子就不會被 resolved }};

ok,以上代碼即可滿足需求3

需求4:

1.A-->B-->C-->D 從A頁面依次進入BCD頁面,現在我要在D頁面點擊返回(手機或者瀏覽器物理返回鍵)回到A頁面

2.A-->E-->D 從A頁面一次進入ED頁面,現在我在D頁面點擊返回(手機或者瀏覽器物理返回鍵)回到E頁面

以上的需求總結來說就是,根據不同的渠道進入D頁面的時候,當點擊返回的時候,進入不同的頁面

1.首先我在入口main.js里面聲明了一個全局變量(當然你可以按照自己的方式去聲明一個變量)

global.beforeRouteName = '';

2.然后在D組件中,聲明路由守衛:beforeRouteEnter,代碼如下:

剛進入該組件時,便會進入beforeRouteEnter,在此先賦值:

beforeRouteEnter(to,from,next){ global.beforeRouteName = from.name; //給全局變量賦值 next(); },

然后在mounted里面判斷瀏覽器是否支持popstate

mounted(){ //判斷瀏覽器是否支持popstate if(window.history && window.history.pushState){ history.pushState(null,null,document.URL); window.addEventListener(’popstate’,this.goBack,false); } }

其次在methods里面寫goBack方法,代碼如下:

goBack(){ if(global.beforeRouteName == 'C'){ //判斷,當獲取上個頁面進來的路由是C的時候,返回到A頁面 this.$router.push({name:’A’}); }else if(global.beforeRouteName == 'E'){//判斷,當獲取上個頁面進來的路由是E的時候,返回上一頁 history.go(-1); }else{ this.$router.push({name:’A’}); //判斷,當有其他返回值的時候,默認返回到A頁面(這個隨意設置,一般不會有這種情況) } }

最后一定不要忘記:在destroyed要取消監聽,不然這個監聽一直存在,代碼如下:

destroyed(){ window.removeEventListener(’popstate’,this.goBack,false);}

到此需求4就解決了。

剛剛看了下代碼,其實路由守衛做這個返回控制其實更簡單。只要好好使用beforeRouteLeave這個守衛就能簡單解決以上問題

補充知識:vue 使用路由守衛監聽返回鍵,控制頁面跳轉

我就廢話不多說了,大家還是直接看代碼吧~

beforeRouteLeave(to, from, next) { // 導航離開該組件的對應路由時調用 // 可以訪問組件實例 `this` if(!this.isPublish){ this.confirmVisible=true next(false)//不放行 }else { next() } },

以上這篇vue 路由緩存 路由嵌套 路由守衛 監聽物理返回操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
视频在线观看一区| 日韩高清一区在线 | 91精品日本| 黑丝一区二区| 久久一级电影| 久久精品在线| 人人草在线视频| 国产精品福利在线观看播放| 久久影院一区二区三区| 成人亚洲精品| 九色porny丨国产首页在线| 亚洲综合电影| 午夜久久中文| 国产精品久久久久9999高清| 国产亚洲精品美女久久 | 亚洲精品91| 午夜欧美视频| 在线观看免费一区二区| 伊人久久婷婷| 国产亚洲激情| 免费成人在线视频观看| 亚洲精一区二区三区| 亚洲人成毛片在线播放女女| 亚洲精品国产日韩| 国产日韩欧美三区| 麻豆国产精品| 丝袜av一区| 激情欧美丁香| 国产一级一区二区| 最新亚洲国产| 国产精品三p一区二区| 久久只有精品| 国产真实久久| 蜜臀va亚洲va欧美va天堂 | 三级欧美韩日大片在线看| 亚洲va久久久噜噜噜久久| 美女视频网站久久| 日本精品影院| 亚洲精选91| 国产精品片aa在线观看| 日本精品不卡| 欧美高清不卡| 日韩一区二区三区免费视频| 久久不卡国产精品一区二区| 亚洲天堂免费电影| 久久国产精品久久久久久电车 | 免费成人在线观看| 日韩不卡免费视频| 成人污污视频| 亚洲手机视频| 亚洲精品美女91| 久久精品欧洲| 免费黄色成人| 国产亚洲精品精品国产亚洲综合| 91日韩在线| 欧美国产一级| 自拍日韩欧美| 欧美一级二级视频| 麻豆91在线播放| 另类亚洲自拍| 精品国产成人| 色8久久久久| 久久精品青草| 日韩国产欧美在线播放| 激情国产在线| 免费成人在线观看| 精品国产免费人成网站| 久久亚洲图片| 精品视频一二| 日韩专区欧美专区| 伊人精品久久| 欧美日韩一区二区三区不卡视频 | 久久影院资源站| 激情欧美国产欧美| 日韩一区二区三区精品视频第3页 日韩一区二区三区免费视频 | 91精品成人| 日韩欧美精品一区二区综合视频| 久久精品女人| 99久精品视频在线观看视频| 日韩欧美久久| 欧美日韩视频网站| 亚洲欧美在线专区| 91偷拍一区二区三区精品| 怡红院精品视频在线观看极品| 夜久久久久久| 国产精品亚洲产品| 国产精品普通话对白| 国产精品99一区二区三| 日本亚洲欧洲无免费码在线| 久久精品国产www456c0m| 日本a级不卡| 99国产精品| 成人在线超碰| 欧美韩一区二区| 日本在线不卡视频| 亚洲精品中文字幕乱码| 日韩av有码| 亚洲三区欧美一区国产二区| 久久理论电影| 日本综合精品一区| 欧美美女一区| 欧美日韩国产观看视频| 日本不卡视频在线观看| 欧美在线亚洲| 精品亚洲美女网站| 黄毛片在线观看| 国产精品jk白丝蜜臀av小说| 视频一区中文字幕| 午夜国产欧美理论在线播放| 成人羞羞在线观看网站| av免费不卡国产观看| 久久精品国产福利| 国产欧美日韩在线一区二区| 蜜臀久久久99精品久久久久久| 精品国产一区二区三区2021| 欧美日韩亚洲三区| 日本综合视频| 亚洲精品日韩久久| 午夜在线精品偷拍| aa亚洲婷婷| 日韩视频不卡| 国产综合婷婷| 久久精品导航| 99久久99视频只有精品| 精品国内亚洲2022精品成人| 国产欧美在线| 欧美午夜不卡影院在线观看完整版免费| 日韩一区欧美二区| 国产精品一线天粉嫩av| 国产日韩欧美一区二区三区| 精品国产一区二区三区2021| 久久国产电影| 亚洲麻豆一区| 丰满少妇一区| 久久99伊人| 成人黄色av| 伊人精品视频| 精品成av人一区二区三区| 九色porny丨国产首页在线| 视频在线观看一区二区三区| 你懂的亚洲视频| 一区二区三区四区日韩| 成人免费一区| 日韩午夜视频在线| 欧美一区激情| 欧美日韩亚洲在线观看| 国产亚洲一区| 日韩中文欧美在线| 精品亚洲成人| 日韩成人午夜精品| 岛国精品一区| 亚洲91精品| 一区二区三区网站| 欧美激情aⅴ一区二区三区| 日韩大片在线观看| 一区在线免费观看| 日韩精品成人| 另类欧美日韩国产在线| 欧美三级精品| 蜜桃免费网站一区二区三区| 欧美久久精品一级c片| 亚洲a级精品| 国产精品www994| 国产一区二区久久久久| 精品在线91| 亚洲精品国产精品粉嫩| 欧美91在线|欧美| 久久久精品国产**网站| 日韩一区亚洲二区| 欧美日韩精品一本二本三本| 中文字幕成人| 欧美激情五月| 蜜桃精品在线| 国产婷婷精品| 国产精品久久久久av蜜臀| 国产精品一区二区三区av麻| 日产午夜精品一线二线三线| 久久成人一区| 久久激情五月婷婷| 欧美精品99| 久久精品色播| 久久精品国产一区二区| a国产在线视频| 欧美国产一级| 樱桃视频成人在线观看| 亚洲精品.com| 亚洲一区欧美二区| 国产成人免费视频网站视频社区| 久久久久伊人| 九一精品国产| 日韩精品一区二区三区中文| 亚洲综合在线电影| 青青青国产精品| 国产在线不卡一区二区三区| 精品国产一区二区三区噜噜噜| 黄色在线观看www| 日韩欧美一区免费| 国精品一区二区| 欧美美女一区| 日韩精品免费视频一区二区三区|