如何从Angular的ActivatedRoute数据结构中获得运行时路由信息
2023-09-14 09:04:01 时间
看个具体的例子:
路由配置信息:
const CUSTOM_ROUTES: Routes = [
{ path: "custom/:id", component: RouteDemoComponent }
];
RouteDemoComponent的实现:
import { Component, OnInit } from '@angular/core';
import { ActivatedRoute } from '@angular/router';
import { Observable } from 'rxjs';
import { map } from 'rxjs/operators';
@Component({
selector: 'app-route-demo',
templateUrl: './route-demo.component.html'
})
export class RouteDemoComponent implements OnInit {
id: Observable<string>;
constructor(route: ActivatedRoute) {
this.id = route.params.pipe(map(p => p.id));
const url: Observable<string> = route.url.pipe(map(segments => segments.join('')));
// route.data includes both `data` and `resolve`
const user = route.data.pipe(map(d => d));
}
ngOnInit(): void {
}
}
浏览器地址栏里输入:
http://localhost:4200/custom/1
运行时查看ActivatedRoute数据结构的值:
凡是behaviorSubject这种Observable,其_value字段里包含了subscribe被调用后,会emit的实际值:
更多Jerry的原创文章,尽在:“汪子熙”:
相关文章
- Angular路由与Nodejs路由的区别
- [Docker] Running Multiple Containers for an Angular, Node project
- [Angular] Enable router tracing
- [Angular] Angular Asynchronous Form Validators
- [Angular2 Animation] Control Undefined Angular 2 States with void State
- [Angular 2] Share a Service Across Angular 2 Components and Modules
- [Angular 2] Understanding Pure & Impure pipe
- Angular 项目里 angular.json 文件内容的学习笔记
- 从 Angular 2 升级到 Angular 13 之后的一些常见错误和解决方案
- Angular 路由的一个问题,以及解决方案
- 如何通过调试的方式搞清楚Angular createEmbeddedView具体创建的UI元素是什么
- Angular 路由的一个问题,以及解决方案
- 为什么Angular的路由执行离不开router-outlet标签
- Angular zone学习笔记
- Angular应用的路由指令RouterLink
- Angular应用内路由(In App Route)的最佳实践
- Angular路由跳转时,如何传递信息
- Angular路由开发的一个实际例子