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方法获取到该路由数据,并在模板中展示。

相关内容

热门资讯

科技辅助!红龙poker辅助指... 科技辅助!红龙poker辅助指令(透视)werplan辅助软件(攻略教程开挂辅助下载);无需打开直接...
固有有开挂"天天微友... 固有有开挂"天天微友亲友圈辅助器"开挂(透视)辅助平台(德州论坛真是有挂)您好:天天微友亲友圈辅助器...
正品辅助!闲逸辅助插件(透视)... 正品辅助!闲逸辅助插件(透视)竞技联盟辅助(切实教程开挂辅助插件);无需打开直接搜索微信(13670...
先前有辅助"陕西辅助... 大家好,今天小编来为大家解答陕西辅助器具适用平台这个问题咨询软件客服可以免费测试直接加微信(1367...
发现辅助!兴动助手辅助器(透视... wepoker有没有辅助开挂教程视频分享装挂详细步骤在当今的网络游戏中,wepoker有没有辅助作为...
一向有辅助"边锋嘉兴... 边锋嘉兴辅助开挂教程视频分享装挂详细步骤在当今的网络游戏中,边锋嘉兴辅助作为一种经典的娱乐方式,吸引...
素来有辅助"微信超级... 素来有辅助"微信超级三加一免费辅助"开挂(透视)辅助插件(黑科技教程有挂实锤)《详细加薇136704...
分析开挂!决战十水三修改器(透... 分析开挂!决战十水三修改器(透视)pokemomo辅助软件(微扑克教程开挂辅助脚本);无需打开直接搜...
本然有开挂"金虎爷辅... 本然有开挂"金虎爷辅助"开挂(透视)辅助神器(必备教程有挂技巧);无需打开直接搜索薇:1367043...
盘点开挂!wepoker辅助透... 盘点开挂!wepoker辅助透视软件(透视)hhpoker的辅助是真的吗(攻略教程开挂辅助工具);无...