Angular - 单例服务只传递给一个组件的更改
创始人
2024-10-14 15:00:55
0

在Angular中,单例服务是指在整个应用程序中只有一个实例的服务。如果您想将单例服务的更改传递给一个组件,可以使用事件或RxJS的Subject来实现。

以下是使用事件的示例:

  1. 创建一个单例服务:
import { Injectable, EventEmitter } from '@angular/core';

@Injectable()
export class MySingletonService {
  public dataChanged: EventEmitter = new EventEmitter();
  
  private data: any;

  setData(data: any) {
    this.data = data;
    this.dataChanged.emit(this.data);
  }
}
  1. 在要接收更改的组件中订阅事件:
import { Component, OnInit } from '@angular/core';
import { MySingletonService } from './my-singleton.service';

@Component({
  selector: 'app-my-component',
  template: `
    
{{ data }}
` }) export class MyComponent implements OnInit { data: any; constructor(private singletonService: MySingletonService) { } ngOnInit() { this.singletonService.dataChanged.subscribe((data: any) => { this.data = data; }); } }
  1. 在发送更改的组件中更新数据:
import { Component } from '@angular/core';
import { MySingletonService } from './my-singleton.service';

@Component({
  selector: 'app-another-component',
  template: `
    
  `
})
export class AnotherComponent {
  constructor(private singletonService: MySingletonService) { }

  updateData() {
    const newData = 'New data';
    this.singletonService.setData(newData);
  }
}

使用RxJS的Subject的示例:

  1. 创建一个单例服务:
import { Injectable } from '@angular/core';
import { Subject } from 'rxjs';

@Injectable()
export class MySingletonService {
  public dataChanged: Subject = new Subject();
  
  private data: any;

  setData(data: any) {
    this.data = data;
    this.dataChanged.next(this.data);
  }
}
  1. 在要接收更改的组件中订阅Subject:
import { Component, OnInit } from '@angular/core';
import { MySingletonService } from './my-singleton.service';

@Component({
  selector: 'app-my-component',
  template: `
    
{{ data }}
` }) export class MyComponent implements OnInit { data: any; constructor(private singletonService: MySingletonService) { } ngOnInit() { this.singletonService.dataChanged.subscribe((data: any) => { this.data = data; }); } }
  1. 在发送更改的组件中更新数据:
import { Component } from '@angular/core';
import { MySingletonService } from './my-singleton.service';

@Component({
  selector: 'app-another-component',
  template: `
    
  `
})
export class AnotherComponent {
  constructor(private singletonService: MySingletonService) { }

  updateData() {
    const newData = 'New data';
    this.singletonService.setData(newData);
  }
}

无论您选择使用事件还是RxJS的Subject,都可以将单例服务的更改传递给一个组件。

相关内容

热门资讯

9分钟了解!中至有挂吗!真是有... 9分钟了解!中至有挂吗!真是有辅助app(有挂辅助)-哔哩哔哩1、游戏颠覆性的策略玩法,独创攻略技巧...
1分钟了解!哥哥打大a外g挂!... 1分钟了解!哥哥打大a外g挂!一贯有辅助脚本(有挂讲解)-哔哩哔哩1、上手简单,内置详细流程视频教学...
第六分钟了解!中至江西源代码!... 第六分钟了解!中至江西源代码!总是是有辅助神器(有挂方针)-哔哩哔哩1、玩家可以在中至江西源代码线上...
8分钟了解!宝宝浙江游戏真的有... 8分钟了解!宝宝浙江游戏真的有辅助嘛!其实一直总是有辅助脚本(有挂总结)-哔哩哔哩1、金币登录送、破...
第十分钟了解!四川途游小程序辅... 第十分钟了解!四川途游小程序辅助破解版!好像一直总是有辅助工具(有挂详细)-哔哩哔哩1、点击下载安装...
第一分钟了解!新天道辅助软件!... 第一分钟了解!新天道辅助软件!一直存在有辅助软件(真的有挂)-哔哩哔哩1、新天道辅助软件脚本辅助下载...
第8分钟了解!情怀宜春辅助!一... 第8分钟了解!情怀宜春辅助!一贯是有辅助神器(有挂教程)-哔哩哔哩1、进入游戏-大厅左侧-新手福利-...
7分钟了解!微信小程序功夫川免... 7分钟了解!微信小程序功夫川免费辅助!一直一直都是有辅助脚本(有挂细节)-哔哩哔哩1、游戏颠覆性的策...
一分钟了解!潮娱乐鱼虾蟹公式辅... 一分钟了解!潮娱乐鱼虾蟹公式辅助软件!真是是有辅助技巧(有挂方略)-哔哩哔哩1、让任何用户在无需潮娱...
第四分钟了解!欢乐卡五星插件!... 第四分钟了解!欢乐卡五星插件!果然是有辅助技巧(有挂解惑)-哔哩哔哩1、下载好欢乐卡五星插件透视辅助...