이 글은 Angular 라우팅에 대한 심층적인 이해를 제공하고, 빠르게 시작하는 방법을 알아보고, 일치 규칙, 라우팅 매개변수, 라우팅 중첩, 라우팅 가드 등을 소개합니다. 모두에게 도움이 되기를 바랍니다!
Angular
에서 라우팅은 모듈을 기반으로 하며 각 모듈은 자체 라우팅을 가질 수 있습니다. [관련 튜토리얼 권장 사항: "Angular
中,路由是以模块为单位的,每个模块都可以有自己的路由。【相关教程推荐:《angular教程》】
创建页面组件、Layout
组件以及 Navigation
组件,供路由使用
创建首页页面组件ng g c pages/home
创建关于我们页面组件ng g c pages/about
创建布局组件ng g c pages/layout
创建导航组件ng g c pages/navigation
创建路由规则
// app.module.ts import { Routes } from "@angular/router" const routes: Routes = [ { path: "home", component: HomeComponent }, { path: "about", component: AboutComponent } ]
引入路由模块并启动
// app.module.ts import { RouterModule, Routes } from "@angular/router" @NgModule({ imports: [RouterModule.forRoot(routes, { useHash: true })], }) export class AppModule {}
添加路由插座
<!-- 路由插座即占位组件 匹配到的路由组件将会显示在这个地方 --> <router-outlet></router-outlet>
在导航组件中定义链接
<a routerLink="/home">首页</a> <a routerLink="/about">关于我们</a>
1、重定向
const routes: Routes = [ { path: "home", component: HomeComponent }, { path: "about", component: AboutComponent }, { path: "", // 重定向 redirectTo: "home", // 完全匹配 pathMatch: "full" } ]
2、<span style="font-size: 16px;">404</span>
页面
const routes: Routes = [ { path: "home", component: HomeComponent }, { path: "**", component: NotFoundComponent } ]
<a routerLink="/about" [queryParams]="{ name: 'kitty' }">关于我们</a>
import { ActivatedRoute } from "@angular/router" export class AboutComponent implements OnInit { constructor(private route: ActivatedRoute) {} ngOnInit(): void { this.route.queryParamMap.subscribe(query => { query.get("name") }) } }
2、动态参数
const routes: Routes = [ { path: "home", component: HomeComponent }, { path: "about/:name", component: AboutComponent } ]
<a [routerLink]="['/about', 'zhangsan']">关于我们</a>
import { ActivatedRoute } from "@angular/router" export class AboutComponent implements OnInit { constructor(private route: ActivatedRoute) {} ngOnInit(): void { this.route.paramMap.subscribe(params => { params.get("name") }) } }
路由嵌套指的是如何定义子级路由
const routes: Routes = [ { path: "about", component: AboutComponent, children: [ { path: "introduce", component: IntroduceComponent }, { path: "history", component: HistoryComponent } ] } ]
<!-- about.component.html --> <app-layout> <p>about works!</p> <a routerLink="/about/introduce">公司简介</a> <a routerLink="/about/history">发展历史</a> <div> <router-outlet></router-outlet> </div> </app-layout>
将子级路由组件显示到不同的路由插座中
{ path: "about", component: AboutComponent, children: [ { path: "introduce", component: IntroduceComponent, outlet: "left" }, { path: "history", component: HistoryComponent, outlet: "right" } ] }
<!-- about.component.html --> <app-layout> <p>about works!</p> <router-outlet name="left"></router-outlet> <router-outlet name="right"></router-outlet> </app-layout>
<a [routerLink]="[ '/about', { outlets: { left: ['introduce'], right: ['history'] } } ]" >关于我们</a>
<!-- app.component.html --> <button (click)="jump()">跳转到发展历史</button>
// app.component.ts import { Router } from "@angular/router" export class HomeComponent { constructor(private router: Router) {} jump() { this.router.navigate(["/about/history"], { queryParams: { name: "Kitty" } }) } }
将根模块中的路由配置抽象成一个单独的路由模块,称之为根路由模块,然后在根模块中引入根路由模块
import { NgModule } from "@angular/core" import { HomeComponent } from "./pages/home/home.component" import { NotFoundComponent } from "./pages/not-found/not-found.component" const routes: Routes = [ { path: "", component: HomeComponent }, { path: "**", component: NotFoundComponent } ] @NgModule({ declarations: [], imports: [RouterModule.forRoot(routes, { useHash: true })], // 导出 Angular 路由功能模块,因为在根模块的根组件中使用了 RouterModule 模块中提供的路由插座组件 exports: [RouterModule] }) export class AppRoutingModule {}
import { BrowserModule } from "@angular/platform-browser" import { NgModule } from "@angular/core" import { AppComponent } from "./app.component" import { AppRoutingModule } from "./app-routing.module" @NgModule({ declarations: [AppComponent], imports: [BrowserModule, AppRoutingModule], providers: [], bootstrap: [AppComponent] }) export class AppModule {}
路由懒加载是以模块为单位的。
创建用户模块 ng g m user --routing=true
并创建该模块的路由模块
创建登录页面组件 ng g c user/pages/login
创建注册页面组件 ng g c user/pages/register
配置用户模块的路由规则
import { NgModule } from "@angular/core" import { Routes, RouterModule } from "@angular/router" import { LoginComponent } from "./pages/login/login.component" import { RegisterComponent } from "./pages/register/register.component" const routes: Routes = [ { path: "login", component: LoginComponent }, { path: "register", component: RegisterComponent } ] @NgModule({ imports: [RouterModule.forChild(routes)], exports: [RouterModule] }) export class UserRoutingModule {}
将用户路由模块关联到主路由模块
// app-routing.module.ts const routes: Routes = [ { path: "user", loadChildren: () => import("./user/user.module").then(m => m.UserModule) } ]
在导航组件中添加访问链接
<a routerLink="/user/login">登录</a> <a routerLink="/user/register">注册</a>
路由守卫会告诉路由是否允许导航到请求的路由。
路由守方法可以返回 boolean
或 Observable <boolean>
或 Promise <boolean>
,它们在将来的某个时间点解析为布尔值
1、<span style="font-size: 16px;">CanActivate</span>
检查用户是否可以访问某一个路由。
CanActivate
为接口,路由守卫类要实现该接口,该接口规定类中需要有 canActivate
方法,方法决定是否允许访问目标路由。
路由可以应用多个守卫,所有守卫方法都允许,路由才被允许访问,有一个守卫方法不允许,则路由不允许被访问。
创建路由守卫:ng g guard guards/auth
import { Injectable } from "@angular/core" import { CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot, UrlTree, Router } from "@angular/router" import { Observable } from "rxjs" @Injectable({ providedIn: "root" }) export class AuthGuard implements CanActivate { constructor(private router: Router) {} canActivate(): boolean | UrlTree { // 用于实现跳转 return this.router.createUrlTree(["/user/login"]) // 禁止访问目标路由 return false // 允许访问目标路由 return true } }
{ path: "about", component: AboutComponent, canActivate: [AuthGuard] }
2、<span style="font-size: 16px;">CanActivateChild</span>
检查用户是否方可访问某个子路由。
创建路由守卫:ng g guard guards/admin
注意:选择
CanActivateChild
,需要将箭头移动到这个选项并且敲击空格确认选择
import { Injectable } from "@angular/core" import { CanActivateChild, ActivatedRouteSnapshot, RouterStateSnapshot, UrlTree } from "@angular/router" import { Observable } from "rxjs" @Injectable({ providedIn: "root" }) export class AdminGuard implements CanActivateChild { canActivateChild(): boolean | UrlTree { return true } }
{ path: "about", component: AboutComponent, canActivateChild: [AdminGuard], children: [ { path: "introduce", component: IntroduceComponent } ] }
3、<span style="font-size: 16px;">CanDeactivate</span>
检查用户是否可以退出路由。比如用户在表单中输入的内容没有保存,用户又要离开路由,此时可以调用该守卫提示用户
import { Injectable } from "@angular/core" import { CanDeactivate, ActivatedRouteSnapshot, RouterStateSnapshot, UrlTree } from "@angular/router" import { Observable } from "rxjs" export interface CanComponentLeave { canLeave: () => boolean } @Injectable({ providedIn: "root" }) export class UnsaveGuard implements CanDeactivate<CanComponentLeave> { canDeactivate(component: CanComponentLeave): boolean { if (component.canLeave()) { return true } return false } }
{ path: "", component: HomeComponent, canDeactivate: [UnsaveGuard] }
import { CanComponentLeave } from "src/app/guards/unsave.guard" export class HomeComponent implements CanComponentLeave { myForm: FormGroup = new FormGroup({ username: new FormControl() }) canLeave(): boolean { if (this.myForm.dirty) { if (window.confirm("有数据未保存, 确定要离开吗")) { return true } else { return false } } return true }
4、<span style="font-size: 16px;">Resolve</span>
angular 튜토리얼"]
레이아웃
구성 요소 및 탐색
만들기 라우팅용 구성 요소ng g c 페이지/홈
ng g c 페이지/about
🎜ng g c 페이지/레이아웃< / code>🎜</li><li>🎜Create<strong>Navigation🎜comComponent<code>ng c Pages/navigation
🎜$ ng g resolver <name>
import { Injectable } from "@angular/core" import { Resolve } from "@angular/router" type returnType = Promise<{ name: string }> @Injectable({ providedIn: "root" }) export class ResolveGuard implements Resolve<returnType> { resolve(): returnType { return new Promise(function (resolve) { setTimeout(() => { resolve({ name: "张三" }) }, 2000) }) } }
{ path: "", component: HomeComponent, resolve: { user: ResolveGuard } }
export class HomeComponent { constructor(private route: ActivatedRoute) {} ngOnInit(): void { console.log(this.route.snapshot.data.user) } }
<span style="font-size: 16px;">404</span>
code> 페이지🎜🎜rrreeeng g m user --routing=true
을 생성하고 이 모듈의 라우팅 모듈을 생성합니다🎜ng g c user/pages/login
🎜ng g c user/pages/register code>🎜
boolean
또는 Observable <boolean>
또는 Promise <boolean>
을 반환할 수 있습니다. 부울로 구문 분석됨 값 🎜🎜1, <span style="font-size: 16px;">활성화 가능</span>
🎜🎜🎜 사용자가 특정 경로에 접근할 수 있는지 확인하세요. 🎜🎜CanActivate
는 인터페이스이며 경로 가드 클래스는 이 인터페이스를 구현해야 합니다. 인터페이스는 클래스에 액세스 허용 여부를 결정하는 canActivate
메서드가 있어야 한다고 규정합니다. 대상 경로로 이동합니다. 🎜🎜한 경로에 여러 개의 가드를 적용할 수 있습니다. 모든 가드 방법이 허용된 경우에만 해당 경로에 대한 접근이 허용됩니다. 하나의 가드 방법이 허용되지 않으면 해당 경로에 대한 접근이 허용되지 않습니다. 🎜🎜라우팅 가드 만들기: ng g 가드 가드/인증
🎜rrreeerrreee🎜 <span>CanActivateChild</span>
🎜🎜🎜사용자가 특정 하위 경로에 액세스할 수 있는지 확인하세요. 🎜🎜경로 가드 만들기: ng g Guardguards/admin
🎜🎜참고: CanActivateChild
를 선택하려면 화살표를 이 옵션으로 이동하고 공백을 눌러야 합니다. 선택을 확인하려면🎜
rrreeerrreee🎜3. CanDeactivate 🎜🎜🎜 사용자가 경로를 종료할 수 있는지 확인하세요. 예를 들어, 사용자가 양식에 입력한 내용이 저장되지 않고 사용자가 경로를 벗어나고 싶어하는 경우 경비원을 호출하여 사용자에게 메시지를 표시할 수 있습니다🎜rrreeerrreeerrreee🎜4. <span style="font-size: 16px;">Resolve</span>
🎜🎜🎜를 사용하면 경로에 진입하기 전에 데이터를 얻은 후 진입할 수 있습니다. 데이터 수집이 완료된 후의 경로🎜rrreeerrreeerrreeerrreee🎜더 보기 프로그래밍 관련 지식은 🎜프로그래밍 비디오🎜를 방문하세요! ! 🎜
위 내용은 Angular의 라우팅과 빠르게 시작하는 방법에 대해 자세히 알아보세요.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!