本文主要為大家分享一篇Vue的路由動態重新導向和導航守衛實例,具有很好的參考價值,希望對大家有幫助。一起跟著小編過來看看吧,希望能幫助大家。根據vue官方文檔,對於重定向有詳細的範例,但是關於使用方法動態重定向的描述卻不多,重定向部分的描述如下:
重定向
重定向也是透過routes 設定來完成,下面範例是從/a 重定向到/b:
const router = new VueRouter({ routes: [ { path: '/a', redirect: '/b' } ] })
重定向的目標也可以是一個已命名的路由:
const router = new VueRouter({ routes: [ { path: '/a', redirect: { name: 'foo' }} ] })
甚至是一個方法,動態返回重定向目標:
const router = new VueRouter({ routes: [ { path: '/a', redirect: to => { // 方法接收 目标路由 作为参数 // return 重定向的 字符串路径/路径对象 }} ] })`这里写代码片`
關於動態重定向的範例如下:
{ path: '/dynamic-redirect/:id?', redirect: to => { const { hash, params, query } = to if (query.to === 'foo') { return { path: '/foo', query: null } } if (hash === '#baz') { return { name: 'baz', hash: '' } } if (params.id) { return '/with-params/:id' } else { return '/bar' } } }
首先參數解構,取得hash、params、query,然後根據取得值進行邏輯判斷之後動態路由重定向。這裡的return值是path值,而不是params值,必須是已經存在的path才能進行路由重定向。而這個path不能使自身,因為作為一個重定向路由跳到自身還要繼續重定向,就會進行一個死循環。
現在需求如下:
為了防止使用者隨便改變路由參數而導致頁面崩潰,需要進行路由重定向,將不符合要求的參數進行重定向到一個規範頁面。例如使用者點選按鈕跳轉/list/1但是使用者自己將1進行改變傳遞不符合規範的參數給頁面,希望能夠在使用者改變參數值後跳到預設的規格頁面
#以上程式碼實現的效果是拿到路由參數,如果使用者將頁面參數改的不符合規範就進行路由重定向。使得頁面可以取得正確參數值。現在的效果是如果使用者輸入/1則進入正常頁面/list/1,輸入/xsajsxoal、/5、/-5 等不符合規範的參數就會跳到/list/0。
雖然重定向的邏輯是沒有問題的但問題依舊存在。那用戶繼續將/list/1改成/list/xsjknxkja怎麼辦呢?
可見重定向是不適合解決這個問題的。這時就用到了vue路由的導航守衛。導航守衛的實作方式如下:
{ path: '/:type', name: 'normal', component: index, beforeEnter (to, from, next) { if (/^[0-3]$/.test(to.params.type)) { next() } else { next('/0') } } }
# 關於導航守衛官方文件描述如下:
##正如其名,vue-router 提供的導航守衛主要用來透過跳轉或取消的方式守衛導航。有多種機會植入路由導航過程中:全局的, 單一路由獨享的, 或組件級的。 記住參數或查詢的改變並不會觸發進入/離開的導航守衛。你可以透過觀察 $route 物件來應對這些變化,或使用 beforeRouteUpdate 的元件內守衛。 你可以使用 router.beforeEach 註冊一個全域前置守衛:const router = new VueRouter({ ... }) router.beforeEach((to, from, next) => { // ... })當一個導覽觸發時,全域前置守衛會依照建立順序呼叫。守衛是非同步解析執行,此時導航在所有守衛 resolve 完成之前一直處於 等待中。
每個守衛方法接收三個參數:
#to: Route: 即將要進入的目標路由對象
from: Route: 目前導覽正要離開的路由
next: Function: 一定要呼叫該方法來resolve 這個鉤子。執行效果依賴 next 方法的呼叫參數。
next(): 進行管道中的下一個鉤子。如果全部鉤子執行完了,則導航的狀態就是 confirmed (確認的)。
next(false): 中斷目前的導航。如果瀏覽器的 URL 改變了(可能是使用者手動或瀏覽器後退按鈕),那麼 URL 位址會重設到 from 路由對應的位址。
next(‘/') 或 next({ path: ‘/' }): 跳到一個不同的位址。目前的導航被中斷,然後進行一個新的導航。next(error): (2.4.0+) 如果傳入next 的參數是一個Error 實例,則導航會被終止且該錯誤會傳遞給router.onError( ) 註冊過的回調。
確保要呼叫 next 方法,否則鉤子就不會被 resolved。 根據需求並不需要使用到全域守衛,只需要使用到路由獨享守衛,因此只需要在路由內添加beforeEnter然後判斷是否符合參數規範,是的話用next() 進入下一個鉤子,否則用next('/')跳到目標位址。 相關推薦:####
以上是Vue路由動態重新導向與導航守衛的詳細內容。更多資訊請關注PHP中文網其他相關文章!

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python更适合数据科学和机器学习,JavaScript更适合前端和全栈开发。1.Python以简洁语法和丰富库生态著称,适用于数据分析和Web开发。2.JavaScript是前端开发核心,Node.js支持服务器端编程,适用于全栈开发。

JavaScript不需要安裝,因為它已內置於現代瀏覽器中。你只需文本編輯器和瀏覽器即可開始使用。 1)在瀏覽器環境中,通過標籤嵌入HTML文件中運行。 2)在Node.js環境中,下載並安裝Node.js後,通過命令行運行JavaScript文件。

如何在Quartz中提前發送任務通知在使用Quartz定時器進行任務調度時,任務的執行時間是由cron表達式設定的。現�...


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

禪工作室 13.0.1
強大的PHP整合開發環境

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)