詳解Angular路由之路由守衛(wèi)-創(chuàng)新互聯(lián)

一、路由守衛(wèi)

創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),福安企業(yè)網(wǎng)站建設(shè),福安品牌網(wǎng)站建設(shè),網(wǎng)站定制,福安網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,福安網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。

當(dāng)用戶滿足一定條件才被允許進(jìn)入或者離開一個(gè)路由。

路由守衛(wèi)場景:

只有當(dāng)用戶登錄并擁有某些權(quán)限的時(shí)候才能進(jìn)入某些路由。

一個(gè)由多個(gè)表單組成的向?qū)?,例如注冊流程,用戶只有在?dāng)前路由的組件中填寫了滿足要求的信息才可以導(dǎo)航到下一個(gè)路由。

當(dāng)用戶未執(zhí)行保存操作而試圖離開當(dāng)前導(dǎo)航時(shí)提醒用戶。

Angular提供了一些鉤子幫助控制進(jìn)入或離開路由。這些鉤子就是路由守衛(wèi),可以通過這些鉤子實(shí)現(xiàn)上面場景。

  1. CanActivate: 處理導(dǎo)航到某路由的情況。
  2. CanDeactivate: 處理從當(dāng)前路由離開的情況。
  3. Resolve: 在路由激活之前獲取路由數(shù)據(jù)。

配置路由時(shí)候用到一些屬性,path, component, outlet, children, 路由守衛(wèi)也是路由屬性。

二、CanActivate

實(shí)例:只讓登錄用戶進(jìn)入產(chǎn)品信息路由。

新建guard目錄。目錄下新建login.guard.ts。

LoginGuard類實(shí)現(xiàn)CanActivate接口,返回true或false,Angular根據(jù)返回值判斷請求通過或不通過。

import { CanActivate } from "@angular/router";

export class LoginGuard implements CanActivate{
  canActivate(){
    let loggedIn :boolean= Math.random()<0.5;
    if(!loggedIn){
      console.log("用戶未登錄");
    }
    return loggedIn;
  }
}

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

當(dāng)前題目:詳解Angular路由之路由守衛(wèi)-創(chuàng)新互聯(lián)
網(wǎng)頁URL:http://muchs.cn/article16/dcjigg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、網(wǎng)站設(shè)計(jì)、網(wǎng)站收錄、企業(yè)建站、微信小程序、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)