這篇文章帶大家了解Angular中的路由守衛(Route Guards),介紹一下創建路由守衛、控制路由是否可以啟動、控制路由是否退出的方法,希望對大家有幫助!
環境:
#Angular CLI: 11.0.6
Angular: 11.0.7
Node: 12.18.3
npm : 6.14.6
#IDE: Visual Studio Code
在我們的實際的業務開發流程中,我們經常會遇到以下需求:
需要限制某些URL 的可存取性,例如,對於系統管理介面,只有那些擁有管理員權限的使用者才能開啟。 【相關教學推薦:《angular教學》】
當使用者處於編輯介面時,在沒有儲存就離開時,需要提示使用者是否放棄修改。
針對以上場景,Angualr使用路由守衛
(Route Guards)來實現。
路由守衛(Route Guards)
1. 建立路由守衛
Angular CLI提供了命令列工具,可以快速建立路由守衛框架檔案:ng generate guard auth
。執行後,Angular CLI會問我們需要實作哪些接口,我們直接勾選即可:
? Which interfaces would you like to implement? (Press <space> to select, <a> to toggle all, <i> to invert selection) >(*) CanActivate ( ) CanActivateChild ( ) CanDeactivate ( ) CanLoad
說明:
CanActivate: 控制路由是否可以啟動
CanActivateChild: 控制子路由是否可以啟動
CanDeactivate: 控制路由是否可以退出
CanLoad : 控制模組(module)是否可以被載入
比較常使用的是1、3,分別控制進入和退出。按照上面配置,AngularCLI自動產生如下程式碼,return true;
替換為我們實際的程式碼即可。 return false;
表示不允許跳轉,或取消離開目前頁面。
// auth.guard.ts import { Injectable } from '@angular/core'; import { CanActivate, CanDeactivate, ActivatedRouteSnapshot, RouterStateSnapshot, UrlTree } from '@angular/router'; import { Observable } from 'rxjs'; @Injectable({ providedIn: 'root' }) export class AuthGuard implements CanActivate, CanDeactivate<unknown> { canActivate( route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean | UrlTree> | Promise<boolean | UrlTree> | boolean | UrlTree { return true; } }
在canActivate方法中,我們也可以使用跳轉。如頁面判斷是否已登錄,如果沒有登錄,跳到Login頁面:
this.router.navigate(['/login']); return false;
#2. 控制路由是否可以啟動
##控制路由是否可以激活,需要定義在定義路由的地方,增加canActivate屬性。如果需要,還可以增加data屬性, 例如告訴我們的AuthGuard進入目前路由需要驗證哪些權限。 data屬性是可選的。const routes: Routes = [ { path: "page1", component: Page1Component, data: { permissions: ['YourPage1Permission'] }, // 传入参数给AuthGuard,可选 canActivate: [AuthGuard] }, { path: "page2", component: Page2omponent, data: { permissions: ['YourPage2Permission'] }, // 传入参数给AuthGuard,可选 canActivate: [AuthGuard] } ]
3. 控制路由是否退出(離開)
#和控制路由是否可以啟動類似,在路由定義增加 canDeactivate,並制定對應的Guard守衛即可。這裡不再舉例
- 透過路由守衛(Route Guards)實現控制URL的進入與離開;
- Angular CLI可以輔助我們建立guard檔;
程式入門! !
以上是Angular學習之路由守衛(Route Guards)淺析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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表達式設定的。現�...

在JavaScript中如何獲取原型鏈上函數的參數在JavaScript編程中,理解和操作原型鏈上的函數參數是常見且重要的任�...

在微信小程序web-view中使用Vue.js動態style位移失效的原因分析在使用Vue.js...

在Tampermonkey中如何對多個鏈接進行並發GET請求並依次判斷返回結果?在Tampermonkey腳本中,我們經常需要對多個鏈...


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

WebStorm Mac版
好用的JavaScript開發工具

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

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

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

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中