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

相关内容

热门资讯

原来有开挂!创思维激k辅助工具... 原来有开挂!创思维激k辅助工具(透视)aapoker安装包怎么使用(2026新版教程开挂辅助透视);...
起初有辅助"天天挂机... 起初有辅助"天天挂机辅助工具"开挂(透视)辅助插件(科技教程有挂攻略);无需打开直接搜索加(薇:13...
往昔有辅助"边锋小程... 边锋小程序辅助免费开挂教程视频分享装挂详细步骤在当今的网络游戏中,边锋小程序辅助免费作为一种经典的娱...
原来有辅助!大唐山西辅助软件苹... 原来有辅助!大唐山西辅助软件苹果版(透视)德普之星怎么开辅助(攻略教程开挂辅助平台);无需打开直接搜...
原本有辅助"陕西辅助... 原本有辅助"陕西辅助"开挂(透视)辅助下载(扑克教程有挂秘笈);无需打开直接搜索加薇13670430...
传授开挂!开挂科技软件免费(透... 传授开挂!开挂科技软件免费(透视)aapoker真的假的(详细教程开挂辅助平台);无需打开直接搜索微...
从前有辅助"老友记 ... 从前有辅助"老友记 十三道辅助"开挂(透视)辅助软件(总结教程存在有挂) 【无需打开直接搜索加薇13...
正版开挂!传送屋辅助软件下载最... 较多好评“微乐万能挂官网”开挂(透视)辅助教程 了解更多开挂安装加(136704302)微信号是一款...
原生有辅助"潮汕掌上... 原生有辅助"潮汕掌上娱脚本"开挂(透视)辅助软件(必胜教程有人有挂)潮汕掌上娱脚本ai黑科技系统规律...
分享辅助!葫芦娃七子降妖内购破... 分享辅助!葫芦娃七子降妖内购破解版下载(透视)wepoker辅助视频(揭秘教程开挂辅助下载)【无需打...