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

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

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

瀏覽:284日期: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://m.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久久,三上悠亚国产精品一区二区三区
久久精品国产99| 国产精品蜜月aⅴ在线| 精品网站aaa| 欧美日本三区| 亚洲精品进入| 蜜桃视频在线观看一区| 亚洲深夜福利| 亚洲一区日韩在线| 亚洲一区日韩| 亚洲精品大片| 欧美激情麻豆| 成人在线视频区| 国际精品欧美精品| 国产乱码精品一区二区三区四区| 日韩福利在线观看| 欧美激情日韩| 成人av三级| 石原莉奈在线亚洲二区| 欧美日韩午夜电影网| 精品国产乱码久久久| 欧美日韩水蜜桃| 中文一区一区三区免费在线观| 中文无码久久精品| 欧美激情在线精品一区二区三区| 成人啊v在线| 亚洲精品系列| av中文资源在线资源免费观看| 狠狠爱成人网| 日韩成人一级| 久久精品国产福利| 激情六月综合| 欧美日韩一区二区高清| 99视频精品全部免费在线视频| 色老板在线视频一区二区| 99成人在线| 久久国产麻豆精品| 久久精品免费一区二区三区| 一区二区亚洲视频| 日韩1区在线| 中文视频一区| 精品亚洲美女网站| 国产精品久久久久久模特 | 亚洲免费精品| 国产精品精品国产一区二区| 丝袜国产日韩另类美女| 中文一区一区三区高中清不卡免费| 亚洲另类视频| 亚洲精品2区| 高清一区二区三区av| 91欧美极品| 在线免费观看亚洲| 9国产精品视频| 久久电影tv| 国产精品xvideos88| 亚洲三级在线| 日韩视频二区| 久久九九99| 高清久久一区| 精品资源在线| 国产91欧美| 国产精品一区二区三区av| 午夜精品福利影院| 日韩一区二区三区免费视频 | 香蕉成人av| 久久久久久自在自线| 精品久久久网| 久久精品一区二区国产| 国产日本久久| 日韩av午夜在线观看| 伊人久久一区| 蜜桃免费网站一区二区三区| 亚洲人亚洲人色久| 日韩高清二区| 国产激情一区| 精品视频97| 国产伦久视频在线观看| 国产精品成久久久久| 国产一区二区三区视频在线| 久久久久久色 | 成人国产精品一区二区免费麻豆| 精品久久影院| 视频二区不卡| 久久国产精品99国产| 亚洲欧美日本日韩| 91精品视频一区二区| 久久女人天堂| 欧美日韩第一| 91精品国产自产在线丝袜啪| 精品欧美视频| 丝袜a∨在线一区二区三区不卡 | 日本不卡的三区四区五区| 国产精品视频一区视频二区| 成人亚洲精品| 国产精品毛片在线| 国产精品久久久久久妇女| 日韩综合一区| 亚洲日产av中文字幕| 麻豆视频久久| 鲁大师影院一区二区三区| 奇米亚洲欧美| 不卡中文字幕| 国产毛片一区二区三区| 午夜久久99| 国产在线观看www| 日本精品久久| 亚洲一级影院| 麻豆理论在线观看| 亚洲青青久久| 午夜久久免费观看| 美女久久精品| 视频一区日韩精品| 欧美1区2区3区| 国产一区二区三区四区| 97精品久久| 亚洲国产日韩欧美在线| 日本在线高清| 里番精品3d一二三区| 日韩精品一页| 羞羞答答国产精品www一本| 91青青国产在线观看精品| 日本成人手机在线| 美日韩精品视频| 久久天堂av| 国产精品成人一区二区不卡| 免费一级欧美片在线观看网站| 亚洲精品成a人ⅴ香蕉片| 夜夜嗨av一区二区三区网站四季av| 日韩一区二区三区在线免费观看| 精品免费av| 麻豆国产91在线播放| 国产伦精品一区二区三区在线播放 | 极品日韩av| 日韩免费看片| 国产欧美一区二区三区精品酒店| 精品国产亚洲一区二区三区大结局| 欧美日本二区| 国产精品xxx| 麻豆成全视频免费观看在线看| 久久电影tv| 亚洲福利国产| 欧美午夜不卡| 亚洲精品日韩久久| 国产欧美精品久久| 久久影院资源站| 精品免费av在线| 亚洲乱亚洲高清| 欧美精品导航| 综合日韩av| 欧美搞黄网站| 91欧美日韩在线| 国产美女高潮在线观看| 婷婷丁香综合| 国产欧美在线观看免费| 日本亚洲欧美天堂免费| 国产欧美另类| 日韩在线中文| 综合激情一区| 麻豆精品少妇| 免费精品国产的网站免费观看| 美日韩精品视频| 国产精品久久久久久久久久妞妞 | 国产亚洲一区二区手机在线观看 | 亚洲精品观看| 日韩欧美精品| 综合一区二区三区| 福利一区和二区| 日韩午夜在线| 国产精品三级| 黄色成人精品网站| 欧美激情aⅴ一区二区三区| 91精品精品| 国产精品丝袜在线播放| 自由日本语亚洲人高潮| 久久亚洲人体| 深夜福利一区| 日韩精品久久久久久久电影99爱| 日韩专区视频网站| 亚洲午夜黄色| 国产中文欧美日韩在线| 日韩高清电影一区| 亚洲精品小说| 日韩欧美一区免费| 欧美偷窥清纯综合图区| 99国产精品久久久久久久| 亚洲黄色网址| 欧美国产专区| 日韩精品导航| 在线国产日韩| 亚洲资源av| 国产精品7m凸凹视频分类| 欧美一级精品| 鲁鲁在线中文| 日韩一区欧美| 精品日韩视频| 欧美日韩精品免费观看视完整| 国模大尺度视频一区二区| 国精品产品一区| 国产专区精品| 精品黄色一级片| 免费精品一区|