首页 > 解决方案 > 根据条件显示不同的视图

问题描述

如果我的 ngfor 为空,我想获得不同的观点

    <ion-select interface="popover" [ngModel]="selectedKidId">
      <ion-option *ngFor="let kid of kids" [value]="kid.id">{{kid.name}}</ion-option>
    </ion-select>
  </ion-item>

这将向我显示孩子姓名的列表,如果列表中没有孩子,我想获得一个调用我创建的组件的不同视图。有办法吗?

谢谢

孩子.ts

export class KidsPage {
  selectedKidId: string
  kids: Kid[] = []
  loveAmount: number

  constructor(
    public navCtrl: NavController,
    public navParams: NavParams,
    public modalCtrl: ModalController,
    private kidProvider: kidProvider,
  ) {
  }

  ionViewDidLoad() {

    this.initKids()
  }

  initkids() {
    this.kidProvider.getkid().subscribe(
      ({ data }) => {
        this.kids = data['mykids']
        if (this.kids.length > 0) {
          this.selectedKidId= this.kids[0].id
        }
      },
      (error) => {
        console.log(`getKids failed: ${JSON.stringify(error)}`)
      })
    this.kidProvider.subscribeToKids()
  }

标签: angularionic-frameworkionic3

解决方案


if-else您也可以像这样在视图中使用条件:

<div *ngIf='kids.length'>
  <ion-select interface="popover" [ngModel]="selectedKidId">
    <ion-option *ngFor="let kid of kids" [value]="kid.id">{{kid.name}}</ion-option>
  </ion-select>
</div>
<add-kid *ngIf='!kids.length'></add-kid>

推荐阅读