亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

vue 解決addRoutes動態添加路由后刷新失效問題

2019-11-19 13:34:57
字體:
來源:轉載
供稿:網友

前言

某些場景下我們需要利用addRoutes動態添加路由,但是刷新后就會失效,前段時間項目里剛好遇到了這個應用場景,所以就花時間研究了一下,做下分享跟記錄,說的不對的地方,請大家指正。

應用場景:用戶a登錄進系統,頁面上有個按鈕,點擊之后會動態添加路由并且跳轉,跳轉過去之后,用戶刷新后也會停留在當前頁面。 不點這個按鈕,瀏覽器輸入地址,用戶會跳到404頁面

github:https://github.com/Mrblackant/keepRouter/tree/master

思路

1.用戶點擊按鈕,用addRutes動態添加路由并跳轉,并把路由保存;
2.用戶在新跳轉的頁面,刷新時利用beforeEach進行攔截判斷,如果發現之前有保存路由,并且判斷新頁面只是刷新事件,再將之前保存的路由添加進來;

代碼

1.按鈕點擊,保存路由并跳轉

(1).在router/index.js里聲明一個數組,里邊是一些固定的路由,比如你的登錄頁面、404等等

//router/index.jsexport const constantRouterMap=[  {   path: '/',   // name: 'HelloWorld',   component: HelloWorld  } ]Vue.use(Router)export default new Router({ routes: constantRouterMap})

(2).按鈕點擊,跳轉、保存路由;

注意,保存路由這一步驟,要做進要跳轉到的組件里,這是為了防止在beforeEach攔截這邊產生死循環

添加路由需要兩點,一是path,二是component,你可以封裝成方法,看著就會簡潔一點,我這里就不做了

記得要用concat方法連接,固定的路由和動態新加的路由,這樣瀏覽器回退的時候也能正常返回

//點擊跳轉<template> <div>  點擊新增 動態路由: "secondRouter"  <br/>  <el-button @click="srouter" type="primary">新增動態路由</el-button> </div></template><script>import router from 'vue-router'import {constantRouterMap} from '@/router'export default { name: 'kk', mounted(){ }, data () {  return {   msg: 'Welcome to Your Vue.js App'  } }, methods:{  srouter(){   let newRoutes=constantRouterMap.concat([{path:'/secondRouter',    component :resolve => require(["@/components/kk"], resolve )   }])   this.$router.addRoutes(newRoutes)   this.$router.push({path:'/secondRouter'})  } }}</script>//跳轉過去的component組件,xxx.vue<template> <div class="secondRoute">  恭喜你,動態添加路由成功,瀏覽器的鏈接已經變化;  <h3>無論你怎么刷新我都會留在當前頁面</h3>  <h3>并且點擊瀏覽器回退鍵,我會跳到之前頁面,不會循環</h3> </div></template><script>import router2 from '@/router'import router from 'vue-router'export default { name: 'HelloWorld', mounted(){   localStorage.setItem('new',JSON.stringify({'path':'/secondRouter','component':'kk'}))//保存路由 }, data () {  return {   msg: 'Welcome to Your Vue.js App'  } }, methods:{ }}</script>

2.路由攔截beforeEach

這里攔截的時候,就判斷localStorage里邊有沒有保存新的動態路由,如果有,就進行判斷,邏輯處理,處理完之后就把保存的路由清除掉,防止進入死循環。

進入第一層判斷后,需要再次判斷一下是不是頁面的刷新事件

import router from './router'import { constantRouterMap } from '@/router' //router里的固定路由router.beforeEach((to, from, next) => { if (localStorage.getItem('new')) {  var c = JSON.parse(localStorage.getItem('new')),  lastUrl=getLastUrl(window.location.href,'/');  if (c.path==lastUrl) { //動態路由頁面的刷新事件   let newRoutes = constantRouterMap.concat([{    path: c.path,    component: resolve => require(["@/components/" + c.component + ""], resolve)   }])   localStorage.removeItem('new')   router.addRoutes(newRoutes)   router.replace(c.path) //replace,保證瀏覽器回退的時候能直接返回到上個頁面,不會疊加  }  }  next()})var getLastUrl=(str,yourStr)=>str.slice(str.lastIndexOf(yourStr))//取到瀏覽器出現網址的最后"/"出現的后邊的字符

ps:一開始我還以為匹配不到路由跳轉404要在攔截這里處理,后來發現根本不用,直接在注冊路由的時候加上下邊兩段就行了:

export const constantRouterMap = [{  path: '/',  component: HelloWorld },  {//404  path: '/404',  component: ErrPage }, { //重定向到404   path: '*', redirect: '/404' }]

整體的思路大概就是這樣,主要就是利用了beforeEach攔截+localStorage的數據存儲,就能完成,addRoutes動態添加路由刷新不失效功能。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
在线视频日本亚洲性| 中文字幕亚洲欧美日韩2019| 国产999在线观看| 欧美精品videos另类日本| 日韩美女免费线视频| 精品国产91乱高清在线观看| 亚洲国产天堂网精品网站| 精品亚洲国产视频| 国产欧美最新羞羞视频在线观看| 92国产精品久久久久首页| 欧美综合激情网| 欧美激情视频一区二区三区不卡| xvideos亚洲| …久久精品99久久香蕉国产| 亚洲欧洲美洲在线综合| 日韩欧美国产免费播放| 欧美日韩国产综合新一区| 国产91露脸中文字幕在线| 91在线播放国产| 国产精品久久一区| 久久综合88中文色鬼| 亚洲国内精品视频| 亚洲变态欧美另类捆绑| 亚洲国产欧美日韩精品| 中文综合在线观看| 亚洲国产又黄又爽女人高潮的| 欧美极品欧美精品欧美视频| 高清欧美电影在线| 亚洲第一福利在线观看| 国产精品午夜国产小视频| 亚洲精品在线91| 日韩人体视频一二区| 欧美性一区二区三区| 色偷偷噜噜噜亚洲男人| 国产精品第三页| 69久久夜色精品国产69| 日韩在线播放一区| 欧美肥婆姓交大片| 色婷婷综合久久久久中文字幕1| 国产精品女人久久久久久| 久久综合网hezyo| 亚洲欧美日韩在线高清直播| 欧美午夜宅男影院在线观看| 国产成人极品视频| 亚洲一区二区国产| 国产日韩欧美黄色| 日韩免费在线免费观看| 国产在线播放91| 91在线色戒在线| 国产伊人精品在线| 久久在线免费视频| 亚洲精品久久久久久久久久久久久| 色偷偷91综合久久噜噜| 亚洲第一免费播放区| 亚洲最新中文字幕| 91精品视频网站| 这里只有精品久久| 国产一区二区美女视频| 国产成人精品日本亚洲专区61| 中文字幕亚洲欧美| 国产精品久久久av| 久久精品一偷一偷国产| 91亚洲精品在线| 日韩高清欧美高清| 中文字幕亚洲一区二区三区五十路| 午夜美女久久久久爽久久| 国产精品久久久久999| 久久国产加勒比精品无码| 亚洲sss综合天堂久久| 中文字幕精品久久久久| 欧美激情乱人伦| 欧美视频免费在线观看| 亚洲国产免费av| 日本久久久久亚洲中字幕| 国产美女精彩久久| 日韩精品久久久久久福利| 亚洲精品国产综合区久久久久久久| 亚洲精品福利视频| 久久成人在线视频| 亚洲无亚洲人成网站77777| 激情成人在线视频| 日本一区二区三区四区视频| 国产午夜精品久久久| 久久久久久国产精品久久| 亚洲直播在线一区| 国产精品欧美一区二区| 青草成人免费视频| 亚洲第一视频网| 国产一区二区在线免费视频| 久久这里有精品| 日本亚洲欧美成人| 亚洲精选在线观看| 另类天堂视频在线观看| 欧美综合在线第二页| 国产日韩精品电影| 国产精品福利网| 欧美一级片一区| 91亚洲国产成人精品性色| 亚洲欧美综合另类中字| 日韩电影中文字幕一区| 久热99视频在线观看| 亚洲色图五月天| 国产精品久久久久久久一区探花| 成人春色激情网| 在线视频免费一区二区| www亚洲精品| 国产精品久久久久久久午夜| 国产亚洲精品久久久久动| 精品国产欧美成人夜夜嗨| 一区二区三区视频观看| 国产精品视频永久免费播放| 国产精品ⅴa在线观看h| 日韩国产高清污视频在线观看| 性色av一区二区三区在线观看| 中文字幕精品在线| 国产有码一区二区| 成人激情在线观看| 岛国视频午夜一区免费在线观看| 亚洲伊人一本大道中文字幕| 欧美成人一区二区三区电影| 91欧美日韩一区| 欧美国产日韩一区二区三区| 日韩免费观看在线观看| 少妇高潮久久久久久潘金莲| 欧美在线免费看| 久久精品91久久香蕉加勒比| 国产精品白丝jk喷水视频一区| 亚洲人成毛片在线播放| 亚洲国产精品美女| 成人精品网站在线观看| 国产视频精品xxxx| 国产亚洲精品美女| 欧美日本在线视频中文字字幕| 国产成人免费91av在线| 91成人天堂久久成人| 欧美激情视频给我| 色综合色综合久久综合频道88| 色www亚洲国产张柏芝| 亚洲免费电影在线观看| 日韩av色综合| 亚洲视频电影图片偷拍一区| 成人欧美一区二区三区在线| 国产成人精品免高潮在线观看| 日本免费久久高清视频| 91精品国产99| 亚洲性生活视频在线观看| 欧美中文字幕精品| 国产精品中文久久久久久久| 日韩欧美国产视频| 久久精品免费电影| 中文字幕一精品亚洲无线一区| 国产日韩欧美在线看| 国产亚洲欧洲黄色| 国产精品嫩草视频| 久久精品亚洲精品| 日韩高清电影好看的电视剧电影| 深夜福利一区二区| 91免费观看网站| 久久综合久久美利坚合众国| 日韩网站免费观看高清| 91国产在线精品| 国产精品a久久久久久| 欧美激情伊人电影| 欧美日韩成人黄色|