欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue路由回退的完美解決方案(vue-route-manager)

 更新時間:2021年09月07日 14:58:29   作者:晝貓  
最近做了一個vue項目關(guān)于路由場景的問題,路由如何回退指定頁面,在此做個記錄,這篇文章主要給大家介紹了關(guān)于Vue路由回退的完美解決方案,主要利用的是vue-route-manager,需要的朋友可以參考下

路由管理器

記錄每次跳轉(zhuǎn)的vue-route name, 內(nèi)置了一些處理回退的方法, 方便回退到指定頁面

背景

筆者所開發(fā)的項目中經(jīng)常遇到各種花式跳轉(zhuǎn), 例如從引導頁的選擇操作到最后的提交審核中間會經(jīng)過無數(shù)頁面, 甚至中間所做的操作不同也會導致最后回退深度不同

假設(shè)項目中 起始點都是選擇頁, 最終都會抵達提交頁 并且都會返回到最初的頁面(選擇頁)

 選擇頁 --> B --> C --> 提交頁
 情況一 從選擇到提交 中間經(jīng)歷了 B、C, 這時候返回 A 需要調(diào)用router.go(-3)
 ----------------------------------------
 ​
 選擇頁 --> B-1 ------> 提交頁
 情況二 從選擇到提交 只經(jīng)歷了 B-1 , 這時候 go(-3) 不再適用, 此時可能會增加查詢參數(shù)(渠道id)來區(qū)分第二種情況
 ----------------------------------------
 ​
 選擇頁 --> B-2 --> C-2 -->C-2-1 --> 提交頁
 這種情況 又會發(fā)現(xiàn)不僅 go(-3) 不適用, 查詢參數(shù)還得多加一種類型, 如果后續(xù)還需要區(qū)分更多渠道, 可想而知啊...

此時可以使用RouteManager插件來處理這一系列復雜的問題

入門

 npm i vue-route-manager -S
 import Vue from 'vue'
 ​
 // 引入 路由管理器
 import VueRouteManager from 'vue-route-manager'
 ​
 // 并將其掛載到 Vue 上
 Vue.use(VueRouteManager, { /* ...ManagerOptions */ })
 ​
 // 此時在頁面中可以用 this.$RouteManager 來訪問管理器

ManagerOptions參數(shù)說明

參數(shù)名 類型 必須 描述
router VueRouter Y VueRouter對象
debug Boolean N 是否開啟調(diào)試

示例

Home 頁

路由信息 { path: '/home', name: 'home', component: Home }

 <template>
     <button @click="jump">下一頁</button>
 </template>
 <script>
 exprot default {
    methods: {
       jump(){
          // 記錄首頁的 name
          this.$RouteManager.setHome('home')
          this.$router.push({ name: 'page-1' })
       }
    }
 }
 </script>

Page-1 頁

路由信息 { path: '/page_1', name: 'page-1', component: Page-1 }

 <template>
     <div class="page-1">
         page-1
         <button @click="$router.push({ name: 'page-2' })">下一頁</button>
         <button @click="$router.replace({ name: 'page-1' })">重定向</button>
     </div>
 </template>

Page-2 頁

路由信息 { path: '/page_2', name: 'page-2', component: Page-2 }

 <template>
     <div class="page-2">
         page-2
         <button @click="$router.push({ name: 'page-3' })">下一頁</button>
         <button @click="backToHome">返回首頁</button>
     </div>
 </template>
 <script>
 exprot default {
    methods: {
       backToHome(){
          // 調(diào)用 backHome 來返回到最開始記錄的 home 頁
          this.$RouteManager.backHome()
       }
    }
 }
 </script>

Page-3 頁

路由信息 { path: '/page_3', name: 'page-3', component: Page-3 }

 <template>
   <div class="page-3">
     page-3
     <button @click="$backToHome">返回首頁</button>
     <button @click="backToPage">返回 page-1</button>
   </div>
 </template>
 exprot default {
    methods: {
       backToPage(){
          // 調(diào)用 backByName 來返回到指定頁(必須經(jīng)歷過此頁面)
          this.$RouteManager.backByName('page-1')
       },
         backToHome(){
          // 調(diào)用 backHome 來返回到最開始記錄的 home 頁
          this.$RouteManager.backHome()
       }
    }
 }
 </script>

解決問題

 A --> B --> C --> D --返回-> A // 情況一
  |--> B-1 ------> D --返回-> A // 情況二
  |--> B-2 --> C-2 -->C-2-1 --> D --返回-> A // 情況三

首先在A頁面調(diào)用this.$RouteManager.setHome('page-A')或者this.$RouteManager.setHome()

接著B頁面需要返回的時候調(diào)用this.$RouteManager.backHome()即可

Methods

setHome([name])

  • name
    • Type: String
    • name所指路由列表當中的 name { path: '/page_3', name: 'page-3', component: Page-3 }
    • Default: 當前路由的name

設(shè)置需要最終返回的頁面路由name

backHome()

回退到home頁, 通過setHome來設(shè)置home

backByName(name)

  • name
    • Type: String
    • name所指路由列表當中的 name { path: '/page_3', name: 'page-3', component: Page-3 }

回退到指定name的頁面

總結(jié)

到此這篇關(guān)于Vue路由回退的完美解決方案vue-route-manager的文章就介紹到這了,更多相關(guān)Vue路由回退內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue項目中keepAlive的使用說明(超級實用版)

    Vue項目中keepAlive的使用說明(超級實用版)

    這篇文章主要介紹了Vue項目中keepAlive的使用說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue3?PC端頁面開發(fā)規(guī)范及說明

    Vue3?PC端頁面開發(fā)規(guī)范及說明

    這篇文章主要介紹了Vue3?PC端頁面開發(fā)規(guī)范及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • vue.js簡單配置axios的方法詳解

    vue.js簡單配置axios的方法詳解

    axios是一個基于Promise 用于瀏覽器和 nodejs 的 HTTP 客戶端,下面這篇文章主要給大家介紹了關(guān)于vue.js簡單配置axios的相關(guān)資料,需要的朋友們可以參考借鑒,需要的朋友們下面來一起學習學習吧。
    2017-12-12
  • vue實現(xiàn)公告欄文字上下滾動效果的示例代碼

    vue實現(xiàn)公告欄文字上下滾動效果的示例代碼

    這篇文章主要介紹了vue實現(xiàn)公告欄文字上下滾動效果的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-06-06
  • vue-router實現(xiàn)編程式導航的代碼實例

    vue-router實現(xiàn)編程式導航的代碼實例

    今天小編就為大家分享一篇關(guān)于vue-router實現(xiàn)編程式導航的代碼實例,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • vue改變數(shù)據(jù)后數(shù)據(jù)變化頁面不刷新的解決方法

    vue改變數(shù)據(jù)后數(shù)據(jù)變化頁面不刷新的解決方法

    這篇文章主要給大家介紹了關(guān)于vue改變數(shù)據(jù)后數(shù)據(jù)變化頁面不刷新的解決方法,vue比較常見的坑就是數(shù)據(jù)(后臺返回)更新了,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-07-07
  • vue3-treeselect數(shù)據(jù)綁定失敗的解決方案

    vue3-treeselect數(shù)據(jù)綁定失敗的解決方案

    這篇文章主要介紹了vue3-treeselect數(shù)據(jù)綁定失敗的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • 詳解vue中移動端自適應(yīng)方案

    詳解vue中移動端自適應(yīng)方案

    這篇文章主要介紹了vue移動端自適應(yīng),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-05-05
  • Vue Extends 擴展選項用法完整實例

    Vue Extends 擴展選項用法完整實例

    這篇文章主要介紹了Vue Extends 擴展選項用法,結(jié)合完整實例形式分析了Vue Extends 擴展選項相關(guān)使用技巧與操作注意事項,需要的朋友可以參考下
    2019-09-09
  • Vue如何實現(xiàn)分頁功能代碼實例

    Vue如何實現(xiàn)分頁功能代碼實例

    這篇文章主要給大家介紹了關(guān)于Vue如何實現(xiàn)分頁功能的相關(guān)資料,Vue分頁功能的實現(xiàn)需要前端和后端共同配合完成,文中通過代碼實例介紹的非常詳細,需要的朋友可以參考下
    2023-09-09

最新評論