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

相关内容

热门资讯

透视辅助!pokemmo手机版... 大家好,今天小编来为大家解答pokemmo手机版透视脚本这个问题咨询软件客服可以免费测试直接加微信(...
课程辅助"禅游指尖四... 课程辅助"禅游指尖四川辅助脚本"开挂(平台)辅助工具(有挂教程) >>您好:软件加薇13670430...
起初有辅助"四川游戏... 起初有辅助"四川游戏家园辅助软件合法吗"详细开挂辅助插件有挂讲解(规律教程);无需打开直接搜索薇:1...
最初有开挂"中至赣牌... 最初有开挂"中至赣牌圈挂件多少钱一个"开挂(透视)辅助平台(微扑克教程揭秘有挂) 了解更多开挂安装加...
总结开挂"神兽h5平... 较多好评“微乐万能挂官网”开挂(透视)辅助教程 了解更多开挂安装加(136704302)微信号是一款...
透视安卓版!三哥玩辅助器软件,... 透视安卓版!三哥玩辅助器软件,微信小程序微乐安徽辅助(透视)开挂辅助神器详细教程!微信小程序微乐安徽...
往昔有开挂"微玩盒子... 往昔有开挂"微玩盒子网页游戏辅助"详细开挂辅助工具有挂秘笈(玩家教你) 【无需打开直接搜索加薇136...
从来有辅助"九哥玩挂... 较多好评“微乐万能挂官网”开挂(透视)辅助教程 了解更多开挂安装加(136704302)微信号是一款...
窍要开挂"菠萝德普辅... 菠萝德普辅助器免费版在哪里 无需打开直接搜索微信:136704302本司针对手游进行,选择我们的四大...
透视免费!友间联盟辅助,新世界... 友间联盟辅助 无需打开直接搜索微信:136704302本司针对手游进行,选择我们的四大理由: 1、软...