Angular中的数组可观察对象需要调用两次才能正常工作
创始人
2024-10-31 10:00:15
0

这个问题通常发生在使用异步数据绑定时,因为数组在异步返回后无法自动更新。为了解决这个问题,我们可以使用RxJS的行为主题(BehaviorSubject)来创建一个可绑定的数组对象。这样一来,只需在初始化时调用一次即可正常工作。

以下是一个示例代码:

import { Component, OnInit } from '@angular/core';
import { BehaviorSubject } from 'rxjs';

interface Person {
  name: string;
  age: number;
}

@Component({
  selector: 'app-person-list',
  template: `
    
{{ person.name }}: {{ person.age }}
` }) export class PersonListComponent implements OnInit { private _people = new BehaviorSubject([]); public get people$() { return this._people.asObservable(); } ngOnInit() { this.fetchPeople(); } private fetchPeople() { // Async API call const people: Person[] = [{ name: 'Alice', age: 30 }, { name: 'Bob', age: 25 }]; this._people.next(people); } }

在这个例子中,我们首先引入了RxJS的行为主题,并定义了一个Person接口。在组件中,我们创建了一个私有的行为主题_people,它的类型是Person数组。我们还定义了一个可观察对象people$,它是_people的asObservable()结果。在fetchPeople()方法中,我们通过异步API调用获取了一个Person数组,并将其传递给_people的next()方法来更新数据。最后,在模板中,我们使用ngFor和async管道来遍历people$可观察对象。

通过这个方法,我们可以避免调用数组可观察对象两次的问题,同时确保我们的数据绑定始终是最新的。

相关内容

热门资讯

第2分钟了解(wpk德州)黑科... 第2分钟了解(wpk德州)黑科技透明挂辅助插件(透视)解密教程(2021已更新)(哔哩哔哩)是一款可...
第7分钟了解(德扑之星数据)软... 第7分钟了解(德扑之星数据)软件透明挂辅助神器(透视)详细教程(2020已更新)(哔哩哔哩)相信很多...
第十分钟了解(wpk作弊)外挂... 您好:wpk作弊这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别好...
第9分钟了解(德州之星手游)黑... 第9分钟了解(德州之星手游)黑科技透明挂辅助ai(透视)软件教程(2020已更新)(哔哩哔哩);亲,...
三分钟了解(微扑克工具)外挂智... 三分钟了解(微扑克工具)外挂智能ai辅助安装(透视)辅助教程(2022已更新)(哔哩哔哩);三分钟了...
六分钟了解(wePoKe)黑科... 六分钟了解(wePoKe)黑科技透明挂辅助安装(透视)AI教程(2020已更新)(哔哩哔哩)相信很多...
1分钟了解(Wepoke是真的... 1分钟了解(Wepoke是真的)软件透明挂辅助下载(透视)wepoke教程(2022已更新)(哔哩哔...
第七分钟了解(aapOKER)... 第七分钟了解(aapOKER)黑科技透明挂辅助下载(透视)软件教程(2022已更新)(哔哩哔哩);大...
五分钟了解(拱趴大菠萝)软件透... 您好:拱趴大菠萝这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别好...
第七分钟了解(aapOker)... 第七分钟了解(aapOker)外挂辅助插件安装软件(透视)必胜教程(2024已更新)(哔哩哔哩);1...