Angular无法通过调用服务来传递路由数据。
创始人
2024-10-30 02:00:33
0

在Angular中,可以通过调用服务来传递路由数据。下面是一个示例解决方法:

首先,创建一个名为RouteDataService的服务,用于存储和获取路由数据。在该服务中,可以使用BehaviorSubject来存储最新的路由数据,并提供一个公共的Observable来订阅这些数据的变化。

import { Injectable } from '@angular/core';
import { BehaviorSubject, Observable } from 'rxjs';

@Injectable({
  providedIn: 'root'
})
export class RouteDataService {
  private routeDataSubject: BehaviorSubject = new BehaviorSubject(null);

  setRouteData(data: any): void {
    this.routeDataSubject.next(data);
  }

  getRouteData(): Observable {
    return this.routeDataSubject.asObservable();
  }
}

接下来,在需要传递路由数据的组件中,注入RouteDataService服务,并使用setRouteData方法来设置路由数据。

import { Component } from '@angular/core';
import { RouteDataService } from 'path/to/route-data.service';

@Component({
  selector: 'app-component',
  template: `
    
  `
})
export class MyComponent {
  constructor(private routeDataService: RouteDataService) {}

  navigate(): void {
    const routeData = { id: 1, name: 'John' };
    this.routeDataService.setRouteData(routeData);
  }
}

最后,在接收路由数据的组件中,也注入RouteDataService服务,并使用getRouteData方法来获取路由数据。

import { Component, OnInit } from '@angular/core';
import { RouteDataService } from 'path/to/route-data.service';

@Component({
  selector: 'app-next-component',
  template: `
    
{{ routeData | async | json }}
` }) export class NextComponent implements OnInit { routeData: any; constructor(private routeDataService: RouteDataService) {} ngOnInit(): void { this.routeData = this.routeDataService.getRouteData(); } }

在上面的示例中,MyComponent组件通过调用setRouteData方法将路由数据设置为{ id: 1, name: 'John' },然后在NextComponent组件中通过订阅getRouteData方法获取到该路由数据,并在模板中展示。

相关内容

热门资讯

wpk辅助挂!wpk ai辅助... wpk辅助挂!wpk ai辅助有没有用,(aApoker)本来是有挂(详细辅助技巧教程)1、这是跨平...
透视科技(aapoker辅助工... 透视科技(aapoker辅助工具存在)微扑克怎么用ai辅助(详细辅助新版2025教程)一直有挂,您好...
德扑数据软件!pokerrrr... 德扑数据软件!pokerrrr2挂,(德州之星)原先存在有挂(详细辅助黑科技教程)需要回顾用户提供的...
透视苹果版(德扑ai助手)德扑... 透视苹果版(德扑ai助手)德扑之星数据解析(详细辅助介绍教程)本来是真的有挂1、玩家可以在软件透明挂...
透视免费(德州之星有外挂)we... 透视免费(德州之星有外挂)wepoke辅助有挂吗(详细辅助存在挂教程)原来存在有挂1、下载好辅助软件...
wepoke真的有挂!云扑克是... wepoke真的有挂!云扑克是否有外挂,(aApoker)一向存在有挂(详细透视技巧教程)1、完成w...
透视教学(aapoker发牌机... 透视教学(aapoker发牌机制)来玩app德州辅助器(详细辅助必备教程)往昔真的是有挂1、不需要A...
wepokeai代打!德扑之星... wepokeai代打!德扑之星怎么设置埋牌,(wePOke)起初真的是有挂(详细透视新2025版);...
透视辅助(德州ai辅助有用)微... 透视辅助(德州ai辅助有用)微扑克辅助机器人(详细辅助技巧教程)切实是有挂1、每个玩家都可以进行使用...
wepoke真的有挂!nzt德... WePoker透视辅助版本稳定性对比与推荐‌:wepoke真的有挂!nzt德州辅助软件基本了解,(w...