vue 解決addRoutes動(dòng)態(tài)添加路由后刷新失效問題
前言
某些場景下我們需要利用addRoutes動(dòng)態(tài)添加路由,但是刷新后就會(huì)失效,前段時(shí)間項(xiàng)目里剛好遇到了這個(gè)應(yīng)用場景,所以就花時(shí)間研究了一下,做下分享跟記錄,說的不對(duì)的地方,請(qǐng)大家指正。
應(yīng)用場景:用戶a登錄進(jìn)系統(tǒng),頁面上有個(gè)按鈕,點(diǎn)擊之后會(huì)動(dòng)態(tài)添加路由并且跳轉(zhuǎn),跳轉(zhuǎn)過去之后,用戶刷新后也會(huì)停留在當(dāng)前頁面。 不點(diǎn)這個(gè)按鈕,瀏覽器輸入地址,用戶會(huì)跳到404頁面
github:https://github.com/Mrblackant/keepRouter/tree/master

思路
1.用戶點(diǎn)擊按鈕,用addRutes動(dòng)態(tài)添加路由并跳轉(zhuǎn),并把路由保存;
2.用戶在新跳轉(zhuǎn)的頁面,刷新時(shí)利用beforeEach進(jìn)行攔截判斷,如果發(fā)現(xiàn)之前有保存路由,并且判斷新頁面只是刷新事件,再將之前保存的路由添加進(jìn)來;
代碼
1.按鈕點(diǎn)擊,保存路由并跳轉(zhuǎn)
(1).在router/index.js里聲明一個(gè)數(shù)組,里邊是一些固定的路由,比如你的登錄頁面、404等等
//router/index.js
export const constantRouterMap=[
{
path: '/',
// name: 'HelloWorld',
component: HelloWorld
}
]
Vue.use(Router)
export default new Router({
routes: constantRouterMap
})
(2).按鈕點(diǎn)擊,跳轉(zhuǎn)、保存路由;
注意,保存路由這一步驟,要做進(jìn)要跳轉(zhuǎn)到的組件里,這是為了防止在beforeEach攔截這邊產(chǎn)生死循環(huán)
添加路由需要兩點(diǎn),一是path,二是component,你可以封裝成方法,看著就會(huì)簡潔一點(diǎn),我這里就不做了
記得要用concat方法連接,固定的路由和動(dòng)態(tài)新加的路由,這樣瀏覽器回退的時(shí)候也能正常返回
//點(diǎn)擊跳轉(zhuǎn)
<template>
<div>
點(diǎn)擊新增 動(dòng)態(tài)路由: "secondRouter"
<br/>
<el-button @click="srouter" type="primary">新增動(dòng)態(tài)路由</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>
//跳轉(zhuǎn)過去的component組件,xxx.vue
<template>
<div class="secondRoute">
恭喜你,動(dòng)態(tài)添加路由成功,瀏覽器的鏈接已經(jīng)變化;
<h3>無論你怎么刷新我都會(huì)留在當(dāng)前頁面</h3>
<h3>并且點(diǎn)擊瀏覽器回退鍵,我會(huì)跳到之前頁面,不會(huì)循環(huán)</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
這里攔截的時(shí)候,就判斷l(xiāng)ocalStorage里邊有沒有保存新的動(dòng)態(tài)路由,如果有,就進(jìn)行判斷,邏輯處理,處理完之后就把保存的路由清除掉,防止進(jìn)入死循環(huán)。
進(jìn)入第一層判斷后,需要再次判斷一下是不是頁面的刷新事件
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) { //動(dòng)態(tài)路由頁面的刷新事件
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,保證瀏覽器回退的時(shí)候能直接返回到上個(gè)頁面,不會(huì)疊加
}
}
next()
})
var getLastUrl=(str,yourStr)=>str.slice(str.lastIndexOf(yourStr))//取到瀏覽器出現(xiàn)網(wǎng)址的最后"/"出現(xiàn)的后邊的字符
ps:一開始我還以為匹配不到路由跳轉(zhuǎn)404要在攔截這里處理,后來發(fā)現(xiàn)根本不用,直接在注冊(cè)路由的時(shí)候加上下邊兩段就行了:
export const constantRouterMap = [{
path: '/',
component: HelloWorld
},
{//404
path: '/404',
component: ErrPage
},
{ //重定向到404
path: '*', redirect: '/404' }
]
整體的思路大概就是這樣,主要就是利用了beforeEach攔截+localStorage的數(shù)據(jù)存儲(chǔ),就能完成,addRoutes動(dòng)態(tài)添加路由刷新不失效功能。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue style屬性設(shè)置背景圖片的相對(duì)路徑無效的解決
這篇文章主要介紹了vue style屬性設(shè)置背景圖片的相對(duì)路徑無效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
Vue2.0 v-for filter列表過濾功能的實(shí)現(xiàn)
今天小編就為大家分享一篇Vue2.0 v-for filter列表過濾功能的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09
vue多頁面項(xiàng)目開發(fā)實(shí)戰(zhàn)指南
一般我們的vue項(xiàng)目都是單頁面的,其實(shí)因?yàn)関ue在工程化開發(fā)的時(shí)候依賴了webpack,webpack幫我們將所有的資源整合到一起而形成一個(gè)單頁面,下面這篇文章主要給大家介紹了關(guān)于vue多頁面項(xiàng)目開發(fā)的相關(guān)資料,需要的朋友可以參考下2022-01-01
Ant Design Vue全局對(duì)話確認(rèn)框(confirm)的回調(diào)不觸發(fā)
這篇文章主要介紹了Ant Design Vue全局對(duì)話確認(rèn)框(confirm)的回調(diào)不觸發(fā)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
Vue 將后臺(tái)傳過來的帶html字段的字符串轉(zhuǎn)換為 HTML
這篇文章主要介紹了Vue 將后臺(tái)傳過來的帶html字段的字符串轉(zhuǎn)換為 HTML ,需要的朋友可以參考下2018-03-03
vue在html標(biāo)簽{{}}中調(diào)用函數(shù)的方法總結(jié)及對(duì)比
這篇文章主要給大家介紹了關(guān)于vue在html標(biāo)簽{{}}中調(diào)用函數(shù)的方法總結(jié)及對(duì)比,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-03-03
vue實(shí)現(xiàn)給div綁定keyup的enter事件
這篇文章主要介紹了vue實(shí)現(xiàn)給div綁定keyup的enter事件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07

