在Angular中,如果你无法从单例服务实例中获取更新后的数据,可能是由于数据的更新不会触发组件的更新,导致无法获取更新后的数据。以下是一种解决方法:
示例代码如下:
单例服务:
import { Injectable } from '@angular/core';
import { BehaviorSubject } from 'rxjs';
@Injectable({
providedIn: 'root'
})
export class DataService {
private dataSubject = new BehaviorSubject('Initial value');
public data$ = this.dataSubject.asObservable();
updateData(newData: string) {
this.dataSubject.next(newData);
}
}
组件:
import { Component, OnInit } from '@angular/core';
import { DataService } from './data.service';
@Component({
selector: 'app-my-component',
template: `
{{ data }}
`
})
export class MyComponent implements OnInit {
data: string;
constructor(private dataService: DataService) {}
ngOnInit() {
this.dataService.data$.subscribe((newData) => {
this.data = newData;
});
}
updateData() {
this.dataService.updateData('New data');
}
}
在上面的示例中,DataService使用BehaviorSubject来保存数据,并在调用updateData方法时更新数据。MyComponent订阅了dataService.data$,并在数据更新时获取新数据并更新组件的data属性,从而触发组件的更新。
这样,当你调用updateData方法更新数据时,组件将会显示新的数据。