Vue路由回退的完美解決方案(vue-route-manager)
路由管理器
記錄每次跳轉(zhuǎn)的vue-route name, 內(nèi)置了一些處理回退的方法, 方便回退到指定頁(yè)面
背景
筆者所開(kāi)發(fā)的項(xiàng)目中經(jīng)常遇到各種花式跳轉(zhuǎn), 例如從引導(dǎo)頁(yè)的選擇操作到最后的提交審核中間會(huì)經(jīng)過(guò)無(wú)數(shù)頁(yè)面, 甚至中間所做的操作不同也會(huì)導(dǎo)致最后回退深度不同
假設(shè)項(xiàng)目中 起始點(diǎn)都是選擇頁(yè), 最終都會(huì)抵達(dá)提交頁(yè) 并且都會(huì)返回到最初的頁(yè)面(選擇頁(yè))
選擇頁(yè) --> B --> C --> 提交頁(yè)
情況一 從選擇到提交 中間經(jīng)歷了 B、C, 這時(shí)候返回 A 需要調(diào)用router.go(-3)
----------------------------------------
選擇頁(yè) --> B-1 ------> 提交頁(yè)
情況二 從選擇到提交 只經(jīng)歷了 B-1 , 這時(shí)候 go(-3) 不再適用, 此時(shí)可能會(huì)增加查詢參數(shù)(渠道id)來(lái)區(qū)分第二種情況
----------------------------------------
選擇頁(yè) --> B-2 --> C-2 -->C-2-1 --> 提交頁(yè)
這種情況 又會(huì)發(fā)現(xiàn)不僅 go(-3) 不適用, 查詢參數(shù)還得多加一種類型, 如果后續(xù)還需要區(qū)分更多渠道, 可想而知啊...
此時(shí)可以使用RouteManager插件來(lái)處理這一系列復(fù)雜的問(wèn)題
入門(mén)
npm i vue-route-manager -S
import Vue from 'vue' // 引入 路由管理器 import VueRouteManager from 'vue-route-manager' // 并將其掛載到 Vue 上 Vue.use(VueRouteManager, { /* ...ManagerOptions */ }) // 此時(shí)在頁(yè)面中可以用 this.$RouteManager 來(lái)訪問(wèn)管理器
ManagerOptions參數(shù)說(shuō)明
參數(shù)名 | 類型 | 必須 | 描述 |
---|---|---|---|
router | VueRouter | Y | VueRouter對(duì)象 |
debug | Boolean | N | 是否開(kāi)啟調(diào)試 |
示例
Home 頁(yè)
路由信息 { path: '/home', name: 'home', component: Home }
<template> <button @click="jump">下一頁(yè)</button> </template> <script> exprot default { methods: { jump(){ // 記錄首頁(yè)的 name this.$RouteManager.setHome('home') this.$router.push({ name: 'page-1' }) } } } </script>
Page-1 頁(yè)
路由信息 { path: '/page_1', name: 'page-1', component: Page-1 }
<template> <div class="page-1"> page-1 <button @click="$router.push({ name: 'page-2' })">下一頁(yè)</button> <button @click="$router.replace({ name: 'page-1' })">重定向</button> </div> </template>
Page-2 頁(yè)
路由信息 { path: '/page_2', name: 'page-2', component: Page-2 }
<template> <div class="page-2"> page-2 <button @click="$router.push({ name: 'page-3' })">下一頁(yè)</button> <button @click="backToHome">返回首頁(yè)</button> </div> </template> <script> exprot default { methods: { backToHome(){ // 調(diào)用 backHome 來(lái)返回到最開(kāi)始記錄的 home 頁(yè) this.$RouteManager.backHome() } } } </script>
Page-3 頁(yè)
路由信息 { path: '/page_3', name: 'page-3', component: Page-3 }
<template> <div class="page-3"> page-3 <button @click="$backToHome">返回首頁(yè)</button> <button @click="backToPage">返回 page-1</button> </div> </template> exprot default { methods: { backToPage(){ // 調(diào)用 backByName 來(lái)返回到指定頁(yè)(必須經(jīng)歷過(guò)此頁(yè)面) this.$RouteManager.backByName('page-1') }, backToHome(){ // 調(diào)用 backHome 來(lái)返回到最開(kāi)始記錄的 home 頁(yè) this.$RouteManager.backHome() } } } </script>
解決問(wèn)題
A --> B --> C --> D --返回-> A // 情況一
|--> B-1 ------> D --返回-> A // 情況二
|--> B-2 --> C-2 -->C-2-1 --> D --返回-> A // 情況三
首先在A頁(yè)面調(diào)用this.$RouteManager.setHome('page-A')或者this.$RouteManager.setHome()
接著B(niǎo)頁(yè)面需要返回的時(shí)候調(diào)用this.$RouteManager.backHome()即可
Methods
setHome([name])
- name
- Type: String
- name所指路由列表當(dāng)中的 name { path: '/page_3', name: 'page-3', component: Page-3 }
- Default: 當(dāng)前路由的name
設(shè)置需要最終返回的頁(yè)面路由name
backHome()
回退到home頁(yè), 通過(guò)setHome來(lái)設(shè)置home
backByName(name)
- name
- Type: String
- name所指路由列表當(dāng)中的 name { path: '/page_3', name: 'page-3', component: Page-3 }
回退到指定name的頁(yè)面
總結(jié)
到此這篇關(guān)于Vue路由回退的完美解決方案vue-route-manager的文章就介紹到這了,更多相關(guān)Vue路由回退內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue項(xiàng)目中keepAlive的使用說(shuō)明(超級(jí)實(shí)用版)
這篇文章主要介紹了Vue項(xiàng)目中keepAlive的使用說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04Vue3?PC端頁(yè)面開(kāi)發(fā)規(guī)范及說(shuō)明
這篇文章主要介紹了Vue3?PC端頁(yè)面開(kāi)發(fā)規(guī)范及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12vue實(shí)現(xiàn)公告欄文字上下滾動(dòng)效果的示例代碼
這篇文章主要介紹了vue實(shí)現(xiàn)公告欄文字上下滾動(dòng)效果的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06vue-router實(shí)現(xiàn)編程式導(dǎo)航的代碼實(shí)例
今天小編就為大家分享一篇關(guān)于vue-router實(shí)現(xiàn)編程式導(dǎo)航的代碼實(shí)例,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-01-01vue改變數(shù)據(jù)后數(shù)據(jù)變化頁(yè)面不刷新的解決方法
這篇文章主要給大家介紹了關(guān)于vue改變數(shù)據(jù)后數(shù)據(jù)變化頁(yè)面不刷新的解決方法,vue比較常見(jiàn)的坑就是數(shù)據(jù)(后臺(tái)返回)更新了,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07vue3-treeselect數(shù)據(jù)綁定失敗的解決方案
這篇文章主要介紹了vue3-treeselect數(shù)據(jù)綁定失敗的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05Vue Extends 擴(kuò)展選項(xiàng)用法完整實(shí)例
這篇文章主要介紹了Vue Extends 擴(kuò)展選項(xiàng)用法,結(jié)合完整實(shí)例形式分析了Vue Extends 擴(kuò)展選項(xiàng)相關(guān)使用技巧與操作注意事項(xiàng),需要的朋友可以參考下2019-09-09Vue如何實(shí)現(xiàn)分頁(yè)功能代碼實(shí)例
這篇文章主要給大家介紹了關(guān)于Vue如何實(shí)現(xiàn)分頁(yè)功能的相關(guān)資料,Vue分頁(yè)功能的實(shí)現(xiàn)需要前端和后端共同配合完成,文中通過(guò)代碼實(shí)例介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09