这可能是因为数据大概率是异步获取的,而同步更新视图导致的。一种常见的解决方法是,使用RxJS中的Observable来获取异步数据,并在使用时等待数据获取完成后再更新视图。下面是相关的代码示例:
在组件中,使用‘Subject’将观察者和可观察者连接起来:
import { Component, OnInit } from '@angular/core';
import { Observable, Subject } from 'rxjs';
import { DataService } from '../data.service';
@Component({
selector: 'app-data-display',
templateUrl: './data-display.component.html',
styleUrls: ['./data-display.component.css']
})
export class DataDisplayComponent implements OnInit {
// 观察者
data$: Observable;
// 可观察者
private dataSubject = new Subject();
constructor(private dataService: DataService) { }
ngOnInit(): void {
this.data$ = this.dataSubject.asObservable();
this.loadData();
}
private loadData(): void {
this.dataService.getData().subscribe(
data => this.dataSubject.next(data),
error => console.error(error)
);
}
}
在模板中,我们等待数据获取完成后再使用它:
{{data.title}}
- {{item}}
请注意'util.js'文件的内容,数据获取的思路。