在条件下显示不同的视图

时间:2018-04-25 04:48:47

标签: angular ionic-framework ionic3

如果我在ngfor

上获得null,我想得到一个不同的视图
    <ion-select interface="popover" [ngModel]="selectedKidId">
      <ion-option *ngFor="let kid of kids" [value]="kid.id">{{kid.name}}</ion-option>
    </ion-select>
  </ion-item>

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

谢谢

kids.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()
  }

1 个答案:

答案 0 :(得分:1)

您可以在视图中使用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>