Angular服务-为什么原始值没有更新?
创始人
2024-10-24 22:31:55
0

在Angular中,当一个原始值在服务中更新时,它不会自动更新到组件中。这是因为原始值是通过复制而不是引用传递到组件中的。

要解决这个问题,可以使用RxJS的BehaviorSubject来创建一个可观察对象,以便在原始值发生变化时通知订阅者。下面是一个示例:

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

@Injectable({
  providedIn: 'root'
})
export class MyService {
  private dataSubject: BehaviorSubject = new BehaviorSubject('initial value');
  public data$ = this.dataSubject.asObservable();

  updateData(newValue: string) {
    this.dataSubject.next(newValue);
  }
}

在上面的示例中,MyService使用了BehaviorSubject来创建了一个名为dataSubject的私有成员变量。这个变量被初始化为一个初始值为"initial value"的BehaviorSubject

MyService还提供了一个updateData方法,用于更新dataSubject的值。通过调用dataSubject.next(newValue),新的值将发送给所有订阅dataSubject的观察者。

在组件中,您可以订阅data$可观察对象来接收更新的值。下面是一个示例:

import { Component, OnInit } from '@angular/core';
import { MyService } from './my.service';

@Component({
  selector: 'app-my-component',
  template: `
    
{{ data }}
` }) export class MyComponent implements OnInit { data: string; constructor(private myService: MyService) { } ngOnInit() { this.myService.data$.subscribe(value => { this.data = value; }); } updateData() { this.myService.updateData('new value'); } }

在上面的示例中,MyComponent通过依赖注入MyService来订阅data$可观察对象。当data$发出新值时,MyComponent会更新data变量的值,从而在模板中显示更新后的值。

通过使用BehaviorSubject可观察对象,您可以确保在原始值发生变化时,组件中的数据也会更新。

相关内容

热门资讯

透视资料!哈糖大菠萝开挂(透视... 透视资料!哈糖大菠萝开挂(透视)哈糖大菠萝免费辅助器(辅助)其实是真的有教程(哔哩哔哩)暗藏猫腻,小...
透视方针!德州辅助工具到底怎么... 透视方针!德州辅助工具到底怎么样(透视)pokemmo辅助脚本(辅助)原来真的是有工具(哔哩哔哩)1...
透视讲义!pokemmo手机版... 透视讲义!pokemmo手机版修改器(透视)红龙poker辅助工具(辅助)本来有方法(哔哩哔哩)1、...
透视步骤!pokermaste... 透视步骤!pokermaster脚本(透视)拱趴大菠萝万能挂(辅助)好像一直都是有技巧(哔哩哔哩)1...
透视指南书!aa poker辅... 透视指南书!aa poker辅助包(透视)epoker底牌透视(辅助)竟然是真的有工具(哔哩哔哩)1...
透视绝活儿!werplan透视... 透视绝活儿!werplan透视挂(透视)impoker辅助(辅助)确实是真的有脚本(哔哩哔哩)1、每...
透视阶段!聚星ai辅助工具下载... 透视阶段!聚星ai辅助工具下载(透视)智星德州辅助译码插件靠谱吗(辅助)真是一直都是有攻略(哔哩哔哩...
透视模板!来玩app破解版(透... 透视模板!来玩app破解版(透视)pokerworld破解版下载(辅助)原来一直总是有app(哔哩哔...
透视窍要!pokermaste... 透视窍要!pokermaster辅助器(透视)哈糖大菠萝能开挂吗(辅助)都是一直总是有app(哔哩哔...
透视指南!pokermaste... 您好,德州私人局怎么透视这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多...