javascript - 为什么 Angular 服务的共享数据没有在 html 中更新?
问题描述
我正在使用一项服务在 02 个不相关的组件“home”和“results”之间共享一个数组。在我的interaction.service.ts
我有这个代码:
import { Injectable } from '@angular/core';
import { Subject } from 'rxjs';
@Injectable({
providedIn: 'root'
})
export class InteractionService {
private _teacherMessageSource = new Subject<any>();
teacherMessage$ = this._teacherMessageSource.asObservable();
constructor() { }
sendMessage(message: any){
this._teacherMessageSource.next(message)
}
}
“消息”是一个浮点数组,但我只是将它设置为任何。当我在“home”组件中从后端得到响应时,我只是将它传递给 Servic 的 sendMessage() 函数:
this.http.post<any>("http://127.0.0.1:5000/", formData).subscribe(
(response)=> {
console.log(response) // array of floats
this._interationService.sendMessage(response);
},
(error)=> console.log(error)
)
然后在结果组件中我得到消息,我可以在控制台上打印它,但是当我将它影响到另一个数组“selectedMessage”以便在 HTML 中打印它时,它总是显示为空:
public selectedMessage=[];
constructor(public _interactionService: InteractionService, private http: HttpClient) { }
ngOnInit(): void {
this.getSpecialities();
this._interactionService.teacherMessage$
.subscribe(
message => {
alert(message); // message is an array of floats and it shows normally with alert(message)
this.selectedMessage = message;
//console.log(this.selectedMessage);
}
);
}
我的html是:
<ul>
<li><strong> SSI </strong>: {{selectedMessage[0]}}</li>
<li> <strong>RSD</strong>:{{selectedMessage[1]}} </li>
<li><strong>IL</strong>: {{selectedMessage[2]}}</li>
<li><strong>MIV</strong>: {{selectedMessage[3]}}</li>
<li><strong>SSI</strong>: {{selectedMessage[4]}}</li>
<li><strong>BIGDATAA</strong>: {{selectedMessage[5]}}</li>
<li><strong>BIOINFO</strong>: {{selectedMessage[6]}} </li>
</ul>
请问可能是什么问题?
解决方案
您正在尝试访问可能不存在的异步数据。直接的解决方案是异步管道。
<ul>
<li *ngFor="let msg of (interactionService.teacherMessage$ | async)">
<strong> Something </strong>: {{msg}}
</li>
</ul>
- 这样可以避免访问空数组
- 链接到 stackblitz 上的示例代码:https ://stackblitz.com/edit/angular-12ziph?file=src/app/app.component.html
推荐阅读
- android - 指纹图像到 ANSI/ISO 模板
- business-process-management - 如何使用实例 ID 从流程实例中提取数据
- javascript - 修改参数时如何覆盖函数?
- python - django 和 boto3 的 AWS S3 图像上传问题
- cloud - 如何使用 gsutil 从文件名中删除 .jpg 已在存储桶中超过 20000 个文件
- html - 如何使用 ngfor 读取的元素作为函数参数
- java - 在 Android 6.0 上切换飞行模式
- javascript - 如何使用触发器 OnEdit () 将一个单元格 (A1) 复制到另一个单元格 (A2)
- python - 如何在 groupby 函数上应用 nsmallest
- javascript - ng-switch 不工作,即使 isactive 为假