如何从Ionic Dynamic Select选项同时获取ID值和NAME值

时间:2019-03-25 17:29:21

标签: angular typescript ionic-framework ionic3 ionic-native

ionic 3,我已经成功实现了动态选择选项,我希望能够将选择的ID值和Name值发送给Option到服务器

因为我只能获取ID或名称,所以不能同时获取两个值,请帮助,我在选项中尝试了JSON.parse以及id.value和name.value,但是可悲的是,我只能获得第一个值,而不能同时获得两个值

 <ion-list >
    <ion-item class="list-but">
      <ion-label>Tipo de Ambiente</ion-label>
      <ion-select
        [(ngModel)]="idType"
        multiple="false"
        cancelText="Cancelar"
        okText="Ok"
      >
        <ion-option
          *ngFor="let type of type_environment"
          value="{{ type.name }}"
          value="{{ type.id }}"
          #name
          >{{ type.name }}</ion-option
        >
      </ion-select>
    </ion-item>
  </ion-list>
  <button ion-button block (click)="insert()">Salvar</button>


``public type_environment = new Array<any>();
  public idType: number = 0;
  public nameType: string = "name";
  private userData: any;`
```

insert() {
    this.userData = this.user.getUserData();

    let body = {
      name: this.nameType,
      id_type: this.idType,
      id_unity: this.navParams.get("id.unidade")
    };
    console.log("name:", this.idType);

    this.route.postData("/ambiente", body).subscribe(
      data => {
        let response = data as any;

        let ret = JSON.parse(response._body);

        if (ret.insertId) {
          this.navCtrl.popToRoot();
        } else {
          console.log(ret);
        }
      },
      error => {
        console.log(error);

1 个答案:

答案 0 :(得分:1)

您无需选择两个value,只需将整个对象绑定到value,即:

<ion-select [(ngModel)]="idType" cancelText="Cancelar" okText="Ok">
  <ion-option *ngFor="let type of type_environment" [value]="type">
    {{ type.name }}
  </ion-option>
</ion-select>

此后,您在idType中具有对象值:

insert() { 
  // below is your chosen object and its properties
  console.log(this.idType.id, this.idType.name)
}

DEMO