繁体   English   中英

Angular 上的可观察数据未显示

[英]Observable data on Angular not displaying

我试图将 API 请求检索到的 Observable 数据传递给组件变量以显示它,但我就是无法使其工作。 请帮忙,这是我的代码。 问候,

TypeScript 服务:请求 API 获取 Observable

export class ServeurService {
  
  serverCharacter = 'https://cegep.fdtt.space/v1/characters';
  serverSecret = 'https://cegep.fdtt.space/v1/secret';
  personnages: any[] = [];
  persoName = '';

  constructor(private http_client: HttpClient) { }

  getPersonnage(): Observable<ICharactere[]> {
    return this.http_client.get<ICharactere[]>(this.serverCharacter).pipe(retry(4));
  }

  getAllInfosById(id: string): Observable<ICharactere> {
    const myUrl = 'https://cegep.fdtt.space/v1/character/' + id;
    return this.http_client.get<ICharactere>(myUrl)?.pipe();
  }

  setPersonnageName(name: string) {
    this.persoName = name;
  }

  getPersonnageName():string {
    return this.persoName;
  }

  getPersonnages() {
    this.http_client.get<any>('https://cegep.fdtt.space/v1/characters').subscribe({
      next: (val) => {
        val.data.forEach((element: { data: any; }) => {
        this.personnages.push(element);
        });
      }
    });
    return this.personnages;
  }

  getPersonnageById(id: string) {
    const persoSelectionne = this.getPersonnages().find((x: { id: string; }) => x.id === id);
    return persoSelectionne;
  }

  getPersonnageIdByName(name: string) {
    const persoSelectionne = this.getPersonnages().find((n: {name: string; }) => n.name === name);
    console.log("perso name service", persoSelectionne)
    return persoSelectionne.id; 
  }

TypeScript 组件:将 Observable 传递给变量

export class StatsComponent implements OnInit {
  
  myCharactere!: any;
  statLookup = [
    { key: 'str', prefix: $localize`str`, suffix: $localize`enght`, couleur: 'bg-danger' },
    { key: 'dex', prefix: $localize`dex`, suffix: $localize`terity`, couleur: 'bg-primary' },
    { key: 'con', prefix: $localize`con`, suffix: $localize`stitution`, couleur: 'bg-warning' },
    { key: 'int', prefix: $localize`int`, suffix: $localize`elligence`, couleur: 'bg-success' },
    { key: 'sag', prefix: $localize`wis`, suffix: $localize`dom`, couleur: 'bg-info' },
    { key: 'cha', prefix: $localize`cha`, suffix: $localize`risma`, couleur: 'bg-dark' }
  ];
  constructor(public myService: ServeurService) { }

  ngOnInit(): void {
    this.myService.getAllInfosById(this.myService.getPersonnageIdByName(this.myService.getPersonnageName())).subscribe(result => {
    this.myCharactere = result
   });
   console.log("stats component perso", this.myCharactere)
  }

  getModifier(stat: number): string {
    const mod = Math.floor((stat-10)/2)
    return (mod<0)?'-':'+'+ mod.toString();
  }
}

HTML:显示变量

<div class="row text-center text-light bg-secondary mt-2  bg-transparent">
    <div class="row mt-5">
        <div class="col-2" *ngFor="let stat of statLookup">
            <div class="{{stat.couleur}} mx-xxl-4 mx-2 mx-md-1 rounded-4">
                <div class="fw-bold">{{stat.prefix}}<span class="d-none d-lg-inline">{{stat.suffix}}</span>
                </div>
                <div class="h2">
                    {{myCharactere && myCharactere.statistics && myCharactere.statistics[stat.key] ? getModifier(myCharactere.statistics[stat.key]) : ''}}
                </div>
                <div class="">
                    {{myCharactere?.data.statistics[stat.key]}}
                </div>
            </div>
    </div>
</div>

如果有帮助,这里也是模型:

export interface ICharactere {
    error: string;
    data: {
    id: string;
    name: string;
    statistics: { [ key : string ]: number }
    race: string;
    player: string;
    classe : string;
    sousclasses: string;
    level: number;
    background: string;
    synopsis: string;
    image: string;
    health: number;
    currentHealth: number;
    traits: {
        trait: string;
        description: string;
    }[];
    // Should be computed
    armorClass: number;
    initiative: number;
    speed: number;
};
}

您在这里混淆了一些基本概念。 首先,您同步调用 getPersonnages() 并进行异步操作的 HTTP 调用。 我明白你想做什么,但如果你打算为你的搜索结果使用 observables,那么我建议你以这种方式使所有函数调用保持一致。 这是一个例子:

getPersonnages(): Observable<any> {
  return this.http.get<any>('https://cegep.fdtt.space/v1/characters');
}

getPersonnageIdByName(name: string) {
  return new Observable(observer => {
    this.getPersonnages().subscribe(
      (results => {
        observer.next(results.data.find(x => x.name === name))
        observer.complete();
      })
    )
  }) 
}

现在您可以像这样搜索您想要的 ID 值:

   this.getPersonnageIdByName("Michel Michaud").subscribe(
      (searchResult => {
        // here I can get the id
        const id = searchResult.id;
      })
    );

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM