Angular路由器:为什么Router ActivatedRoute.children是一个数组/始终只有一个子级?
创始人
2024-10-28 04:30:15
0

在Angular中,当使用路由器进行导航时,可以使用ActivatedRoute来访问当前路由的信息,包括路由参数、查询参数等。而ActivatedRoute对象的children属性是一个包含当前路由的子路由的数组。

通常情况下,ActivatedRoute.children数组只有一个子级,这是因为路由配置中定义了一个子路由。如果路由配置中没有定义子路由,children数组将为空。但是,ActivatedRoute.children始终是一个数组,即使只有一个子级。

以下是一个示例来解释为什么ActivatedRoute.children是一个数组/始终只有一个子级的原因:

// app.module.ts
import { NgModule } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';
import { AppComponent } from './app.component';
import { HomeComponent } from './home.component';
import { AboutComponent } from './about.component';

const routes: Routes = [
  { path: '', component: HomeComponent },
  { path: 'about', component: AboutComponent, children: [
    { path: 'child', component: ChildComponent }
  ]},
];

@NgModule({
  imports: [RouterModule.forRoot(routes)],
  exports: [RouterModule]
})
export class AppModule { }

// about.component.ts
import { Component } from '@angular/core';
import { ActivatedRoute } from '@angular/router';

@Component({
  selector: 'app-about',
  template: `
    

About Page

` }) export class AboutComponent { constructor(private route: ActivatedRoute) { console.log(route.children); // [ActivatedRoute] } } // child.component.ts import { Component } from '@angular/core'; import { ActivatedRoute } from '@angular/router'; @Component({ selector: 'app-child', template: `

Child Page

` }) export class ChildComponent { constructor(private route: ActivatedRoute) { console.log(route.children); // [] } }

在上面的示例中,我们定义了一个父级路由about和一个子级路由child。当访问/about时,AboutComponent会被加载,并且route.children将包含一个ActivatedRoute对象。而当访问/about/child时,ChildComponent会被加载,并且route.children将为空数组。

通过以上示例,你可以看到ActivatedRoute.children是一个数组,即使只有一个子级。你可以通过访问route.children[0]来获取子级的ActivatedRoute对象。

相关内容

热门资讯

黑科技计算!好运大菠萝有辅助(... 黑科技计算!好运大菠萝有辅助(微扑克透牌)原本真的是有挂(有挂技术)-哔哩哔哩1、快速入门:当你通过...
黑科技有挂!微扑克德州专用辅助... 黑科技有挂!微扑克德州专用辅助器(德扑ai机器人软件开发)一直是真的有挂(的确有挂)-哔哩哔哩1、玩...
黑科技讲解!gg扑克软件(德州... 黑科技讲解!gg扑克软件(德州ai辅助神器软件)固有存在有挂(证实有挂)-哔哩哔哩;无聊就玩这款德州...
黑科技神器!众合推扑克有辅助(... 黑科技神器!众合推扑克有辅助(aapoker发牌机制)往昔存在有挂(有挂解惑)-哔哩哔哩1、每一步都...
黑科技教程!cloud辅助(线... 黑科技教程!cloud辅助(线上wpk德州ai机器人)原本是有挂(确实有挂)-哔哩哔哩1、打开德州p...
黑科技实锤!wepoke黑科技... 黑科技实锤!wepoke黑科技设备(aapokerai辅助)往昔是真的有挂(真实有挂)-哔哩哔哩;人...
黑科技插件!德扑之星辅牌软件(... 黑科技插件!德扑之星辅牌软件(aapoker真的有猫腻吗)好像是真的有挂(有挂方针)-哔哩哔哩;一、...
黑科技新版!aapokerai... 黑科技新版!aapokerai辅助(德扑AI策略软件)果然存在有挂(有挂方式)-哔哩哔哩1、很好的工...
黑科技安卓版!gg扑克发牌是有... 黑科技安卓版!gg扑克发牌是有机制(微扑克透牌)往昔是真的有挂(竟然有挂)-哔哩哔哩1、在微扑克透牌...
黑科技挂!wpk有猫腻(wep... 1、黑科技挂!wpk有猫腻(wepokeai代打)素来有挂(详细教程)-哔哩哔哩;该软件可以轻松地帮...