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

vue 解決addRoutes動(dòng)態(tài)添加路由后刷新失效問題

 更新時(shí)間:2018年07月02日 09:38:01   作者:大師兄  
這篇文章主要介紹了vue 解決addRoutes動(dòng)態(tài)添加路由后刷新失效問題,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

前言

某些場(chǎng)景下我們需要利用addRoutes動(dòng)態(tài)添加路由,但是刷新后就會(huì)失效,前段時(shí)間項(xiàng)目里剛好遇到了這個(gè)應(yīng)用場(chǎng)景,所以就花時(shí)間研究了一下,做下分享跟記錄,說的不對(duì)的地方,請(qǐng)大家指正。

應(yīng)用場(chǎng)景:用戶a登錄進(jìn)系統(tǒng),頁(yè)面上有個(gè)按鈕,點(diǎn)擊之后會(huì)動(dòng)態(tài)添加路由并且跳轉(zhuǎn),跳轉(zhuǎn)過去之后,用戶刷新后也會(huì)停留在當(dāng)前頁(yè)面。 不點(diǎn)這個(gè)按鈕,瀏覽器輸入地址,用戶會(huì)跳到404頁(yè)面

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

思路

1.用戶點(diǎn)擊按鈕,用addRutes動(dòng)態(tài)添加路由并跳轉(zhuǎn),并把路由保存;
2.用戶在新跳轉(zhuǎn)的頁(yè)面,刷新時(shí)利用beforeEach進(jìn)行攔截判斷,如果發(fā)現(xiàn)之前有保存路由,并且判斷新頁(yè)面只是刷新事件,再將之前保存的路由添加進(jìn)來;

代碼

1.按鈕點(diǎn)擊,保存路由并跳轉(zhuǎn)

(1).在router/index.js里聲明一個(gè)數(shù)組,里邊是一些固定的路由,比如你的登錄頁(yè)面、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ì)簡(jiǎn)潔一點(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)前頁(yè)面</h3>
  <h3>并且點(diǎn)擊瀏覽器回退鍵,我會(huì)跳到之前頁(yè)面,不會(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)入第一層判斷后,需要再次判斷一下是不是頁(yè)面的刷新事件

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)路由頁(yè)面的刷新事件
   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è)頁(yè)面,不會(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)添加路由刷新不失效功能。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Xx-vue自定義指令實(shí)現(xiàn)點(diǎn)擊水波紋漣漪效果

    Xx-vue自定義指令實(shí)現(xiàn)點(diǎn)擊水波紋漣漪效果

    這篇文章主要為大家介紹了Xx-vue自定義指令實(shí)現(xiàn)點(diǎn)擊水波紋漣漪效果,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • Vue.extend實(shí)現(xiàn)掛載到實(shí)例上的方法

    Vue.extend實(shí)現(xiàn)掛載到實(shí)例上的方法

    這篇文章主要介紹了Vue.extend實(shí)現(xiàn)掛載到實(shí)例上的方法,結(jié)合實(shí)例形式分析了Vue.extend實(shí)現(xiàn)掛載到實(shí)例上的具體操作步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2019-05-05
  • vue3實(shí)戰(zhàn)-子組件之間相互傳值問題

    vue3實(shí)戰(zhàn)-子組件之間相互傳值問題

    這篇文章主要介紹了vue3實(shí)戰(zhàn)-子組件之間相互傳值問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 用Vue.js在瀏覽器中實(shí)現(xiàn)裁剪圖像功能

    用Vue.js在瀏覽器中實(shí)現(xiàn)裁剪圖像功能

    在本教程中,我們將探討如何在瀏覽器中使用 JavaScript 庫(kù)來操作圖片,為服務(wù)器上的存儲(chǔ)做準(zhǔn)備,并在 Web 程序中使用。我們將使用 Vue.js 而不是原生 JavaScript來完成此操作,需要的朋友可以參考下
    2019-06-06
  • 解決vue3項(xiàng)目打包發(fā)布到服務(wù)器后訪問頁(yè)面顯示空白問題

    解決vue3項(xiàng)目打包發(fā)布到服務(wù)器后訪問頁(yè)面顯示空白問題

    這篇文章主要介紹了解決vue3項(xiàng)目打包發(fā)布到服務(wù)器后訪問頁(yè)面顯示空白問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Vue對(duì)象的單層劫持圖文詳細(xì)講解

    Vue對(duì)象的單層劫持圖文詳細(xì)講解

    這篇文章主要介紹了vue2.x對(duì)象單層劫持的原理實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • 在Vue中使用Avue、配置過程及實(shí)際應(yīng)用小結(jié)

    在Vue中使用Avue、配置過程及實(shí)際應(yīng)用小結(jié)

    在項(xiàng)目中遇到通過點(diǎn)擊加號(hào)實(shí)現(xiàn)輸入框的增加、以及對(duì)該輸入框的輸入內(nèi)容進(jìn)行驗(yàn)證,通過這些誘導(dǎo)因素創(chuàng)作的這篇文章,本文重點(diǎn)給大家介紹在Vue中使用Avue、配置過程以及實(shí)際應(yīng)用,需要的朋友可以參考下
    2022-10-10
  • 最新評(píng)論