首頁  >  文章  >  web前端  >  淺談Angular中如何使用路由?

淺談Angular中如何使用路由?

青灯夜游
青灯夜游轉載
2021-09-01 18:38:033070瀏覽

Angular中如何使用路由?這篇文章就來帶大家了解一下Angular中使用路由的方法,快速入門Angular路由,希望對大家有幫助!

淺談Angular中如何使用路由?

路由的概念在前端的框架中得到了廣泛的應用,對於路由的感念不做闡述,路由的應用無外乎就是嵌套、傳參,高級一些的功能如懶加載、預先加載,再高級一些的如:路由守衛等。本篇我們就一起來看看Angular如何使用路由。 【相關教學推薦:《angular教學》】

請依照圖中結構來建立我們的專案

淺談Angular中如何使用路由?

建立專案&一級模組:

  • ng new angular-router-sample

  • ng g c pages/login

  • #ng g c pages/home

  • ng g c pages/mine

註:透過cli建立的元件會進行自動註冊。

起步

1. 在App的html範本中設定

#設定路由跳轉&路由出口(router- outlet

<div>
  <a [routerLink]="[&#39;/login&#39;]">登陆</a>|
  <a [routerLink]="[&#39;/home&#39;]">首页</a>|
  <a [routerLink]="[&#39;/mine&#39;]">我的</a>
</div>
<!-- 配置路由出口 -->
<router-outlet></router-outlet>

2. 在App的app-routing中設定路由器

  • 一個最簡單的元件路由必備一個path(路由的Url)屬性和一個component(Url對應加載的元件)屬性:

const routes: Routes = [
  {
    path: &#39;login&#39;,
    component: LoginComponent,
  },
  {
    path: &#39;home&#39;,
    component: HomeComponent,
  },
  {
    path: &#39;mine&#39;,
    component: MineComponent,
  },
];
  • 當我們意外訪問了一個不存在的Url的時候我們的404頁面怎麼配置?

path支援一個特殊的通配符來支援“**”,當在路由表中沒有成功匹配的情況下會最後指向通配符對應的元件

const routes: Routes = [
  ...
  {
    path: &#39;**&#39;,
    component: NotFountComponent,
  },
];

注意:路由器匹配策略為先到先得,故不具體的路由配置靠後配置。

3. 設定有效的預設路由

由於我們專案預設啟動後無具體路由匹配這樣並不友好,我們需要設定一個有效的默認路由來展示給使用者。

  • 配置的預設路由應該在通配路由之上。

const routes: Routes = [
  ...
  { path: '', redirectTo: '/home', pathMatch: 'full' },
  ...
];

設定子模組&子路由

#此時我們的路由設定全部app-routing ,這樣對於簡單的應用當然是可行的,但是隨著應用的迭代、模組的增加顯然配置在一起對於管理和擴展都是一項挑戰,模組的拆分就成來必然。

1. 為Home元件增加帶路由的模組配置

透過cli為Home元件建立帶路由的模組配置: ng generate module pages/home/home --module app --flat --routing

#
imports: [
    BrowserModule,
    HomeRoutingModule,
    AppRoutingModule,
]

註:用cli建立的模組會自動配置到根模組,但我們手動的調整一下順序將AppRoutingModule移到最後,滿足先到先得的策略。

2. 將Home元件的路由設定轉移到home-routing

#
const routes: Routes = [{
  path: &#39;home&#39;,
  component: HomeComponent,
}];

:配置好後就可以把app -routing 中的Home元件配置移除了。

3. 補充Home群組模組的子元件並配置子路由

  • #執行一下指令建立子元件

    • ng g c pages/home/children/user-list

    • #ng g c pages/home/children/user-detail

    • #ng g c pages/home/children/edit-user

  • 為Home路由器設定增加 children屬性來設定子元件路由

const routes: Routes = [{
  ...
  children: [
    {
      path: &#39;list&#39;,
      component: UserListComponent,
    },
    {
      path: &#39;detail&#39;,
      component: UserDetailComponent,
    },
    {
      path: &#39;edit&#39;,
      component: EditUserComponent,
    },
    {
      path: &#39;&#39;,
      redirectTo: &#39;/home/list&#39;,
      pathMatch: &#39;full&#39;
    }
  ]
}];
  • #同根元件一樣設定子模組路由出口

<div>
  <a [routerLink]="[&#39;/home/list&#39;]">列表</a>|
  <a [routerLink]="[&#39;/home/edit&#39;]">编辑</a>|
  <a [routerLink]="[&#39;/home/detail&#39;]">详情</a>
</div>
<!-- 配置路由出口 -->
<router-outlet></router-outlet>

#路由傳參

1. 在路由定義時設定需要攜帶的參數令牌

  • ##格式: 在路由配置的path後補充格式為

    /:key的令牌佔位

  • {
      path: &#39;detail/:id&#39;,
      component: UserDetailComponent
    }
註:這種將令牌插入到路由path中進行佔位的方式中id是必須攜帶的參數。

  • 透過

    routerLink攜帶參數

<a></a>
  • 在Angular取得路由參數需要用到ActivatedRoute :

使用

ActivatedRoute前要在目標元件進行注入

  • 方式1: 获取参数(路由参数变化可以被监听,适用于同一组件实例多次复用的情况)

this.route.paramMap.subscribe(
  (params: ParamMap) => {
    console.log(&#39;id :>> &#39;, params.get(&#39;id&#39;));
  }
)
  • 方式2: 获取参数(只获取到初始值)

const id = this.route.snapshot.paramMap.get(&#39;id&#39;)!;

ParamMap API:

成员 说明
has(name) 如果参数名位于参数列表中,就返回 true
get(name) 如果这个 map 中有参数名对应的参数值(字符串),就返回它,否则返回 null。如果参数值实际上是一个数组,就返回它的第一个元素。
getAll(name) 如果这个 map 中有参数名对应的值,就返回一个字符串数组,否则返回空数组。当一个参数名可能对应多个值的时候,请使用 getAll
keys 返回这个 map 中的所有参数名组成的字符串数组。

2. 通过Router的navigate跳转页面

当前组件注入Router对象

  • 无参数携带跳转:

this.router.navigate([&#39;/home/list&#39;]);
  • 携带参数跳转:

this.router.navigate([&#39;/home/list&#39;, { id: this.userId, name: this.userName }]);

注:矩阵URL标记法:;id=101;name=bom

懒加载

懒加载的目的是将模块的挂载延迟到我们使用的时候,避免首次打开页面就进行整体加载导致页面长时间不可用。

1. 配置无组件路由(空路由)

对路由进行分组而不增加额外的路径片段

{
    path: &#39;home&#39;,
    loadChildren: () =>
      import(&#39;./pages/home/home.module&#39;).then((m) => m.HomeModule),
}

2. 移除根模块中关于Home模块的导入,使得模块完整分离

微调home-routing中home组件的path配置为""

const routes: Routes = [{
  path: &#39;&#39;,
  component: HomeComponent,
  children: [
    ...
  ]
}];

3. 与懒加载相对的预加载

angular中配置懒加载后模块的加载被延迟到来使用时,但是有一些组件是需要优先加载并在使用的时候可以及时运行。

angular中的Router模块提供来两种预加载的策略:

  • 完全不预加载,这是默认值。惰性加载的特性区仍然会按需加载。

  • 预加载所有惰性加载的特性区。

  • 修改方式:RouterModule.forRoot()的参数二的对象支持设置加载模式的属性preloadingStrategy

    • PreloadAllModules: 预加载有所模块

    • NoPreloading: 默认,不进行预加载

  • 这么鸡肋的属性必须要支持自定义,我们来看一下:

    • 在需要预加载的路由配置对象中添加data对象并增加preload属性,值设置为true表示开启预加载。

    • 通过cli来生成一个服务用来完成我们的预加载策略:ng generate service selective-preloading-strategy

    • 将我们创建的服务实现接口PreloadingStrategy

    • 自定义的策略和默认支持的两种策略使用方法一致。

import { Injectable } from &#39;@angular/core&#39;;
import { PreloadingStrategy, Route } from &#39;@angular/router&#39;;
import { Observable, of } from &#39;rxjs&#39;;

@Injectable({
  providedIn: &#39;root&#39;,
})
export class SelectivePreloadingStrategyService implements PreloadingStrategy {
  preloadedModules: string[] = [];

  preload(route: Route, fn: () => Observable<any>): Observable<any> {
    // 通过检查路由配置来决定是否做预加载
    if (route.data && route.data.preload && route.path != null) {
      // 参数1: 要加载的路由
      this.preloadedModules.push(route.path);
      // 参数2: 加载器
      return fn();
    } else {
      return of(null);
    }
  }
}

结语

以上就是最近对Angular路由的学习整理,对于路由还有一块守卫没有提到,我们抽时间再来整理一下。

更多编程相关知识,请访问:编程入门!!

以上是淺談Angular中如何使用路由?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:juejin.cn。如有侵權,請聯絡admin@php.cn刪除