如何从ion-select选项中获取值

时间:2016-09-15 05:46:23

标签: angular typescript ionic-framework ionic2 ionic3

我有一个名为选项的对象数组。

这是我的HTML代码

    <ion-item>
        <ion-label>place</ion-label>

        <ion-select [(ngModel)]="place" (click)="optionsFn(item);">
          <ion-option value="item" *ngFor="let item of options">{{item.name}} &nbsp;&nbsp;{{item.price}}</ion-option> 
        </ion-select>
      </ion-item>

{{salespriceOp}}

{{quantityOp}}

这是我的.ts文件代码

product_option_value_idOp
  priceOp
  salespriceOp
  quantityOp
  skuOp
  nameOp

  options =  [
          {
            "product_option_value_id": "45",
            "name": "Bangalore Auto",
            "quantity": "12",
            "sku": "56876",
            "price": "100.00",
            "salesprice": "50"
          },
          {
            "product_option_value_id": "51",
            "name": "Hyderabad Auto",
            "quantity": "23",
            "sku": "56543",
            "price": "200.00",
            "salesprice": "60"
          },
          {
            "product_option_value_id": "52",
            "name": "Delhi Auto",
            "quantity": "14",
            "sku": "98767",
            "price": "300.00",
            "salesprice": "80"
          }
        ];
  constructor(public navCtrl: NavController) {

  }

  optionsFn(item) {//here item is an object 
    console.log(item);
    this.product_option_value_idOp = item.product_option_value_id;
    this.priceOp = item.price;
    this.salespriceOp = item.salesprice;
    this.quantityOp = item.quantity;
    this.skuOp = item.sku;
    this.nameOp = item.name;
  }
  

我可以调用该函数,但我在console.log(item)

中未定义

6 个答案:

答案 0 :(得分:13)

有几件事情共同造成了这个错误。 第一个更改是,而不是像这样使用click事件:

(click)="optionsFn(item);

您应该使用Ionic公开的ionChange事件:

(ionChange)="optionsFn();"

另请注意,由于您使用[(ngModel)]="place"将select元素绑定到组件的某个属性,因此您无需将该项目作为参数发送,因为this.place将被选中触发ionChange事件时的项目。

这就是你的optionsFn方法看起来像这样的原因:

public optionsFn(): void { //here item is an object 
    console.log(this.place);

    let item = this.place; // Just did this in order to avoid changing the next lines of code :P

    this.product_option_value_idOp = item.product_option_value_id;
    this.priceOp = item.price;
    this.salespriceOp = item.salesprice;
    this.quantityOp = item.quantity;
    this.skuOp = item.sku;
    this.nameOp = item.name;
  }

答案 1 :(得分:1)

使用(ngModelChange)代替(click)事件。

(ngModelChange)="optionsFn()"

每当模型值改变时,ngModelChange将自动调用相对函数。

<ion-item>
  <ion-label>place</ion-label>
  <ion-select [(ngModel)]="place" (ngModelChange)="optionsFn(item)">
      <ion-option value="item" *ngFor="let item of options">{{item.name}} &nbsp;&nbsp;{{item.price}}</ion-option> 
  </ion-select>
</ion-item>

答案 2 :(得分:0)

  1. 关于离子选择元素集 #id(ionChange)="anyFunc()"
<ion-select (ionChange)="anyFunc()" #anyName>
  <ion-option value="{{item.id}}" *ngFor="let item of apicall?.items"></ion-option>
</ion-select>
  1. 相应地编辑 ts 文件。最重要的是将 ViewChild 设置为来自 Select
  2. ionic-angular 类型
import { Select } from 'ionic-angular';

@ViewChild('anyName') theSelectObject: Select;

contructor() { }

anyFunc() {
    const theValue = this.theSelectObject.value;
}

祝你好运!

答案 3 :(得分:0)

你可以这样做

<ion-select (ionChange)="itemId = $event.target.value">
  <ion-select-option *ngFor="let s of itemIds" value="{{s.id}}">{{s.name}}</ion-select-option>
</ion-select>

或者你也可以这样做

<ion-select value="{{itemId}}" [(ngModel)]="itemId">
  <ion-select-option *ngFor="let s of itemIds" value="{{s.id}}">{{s.name}}</ion-select-option>
</ion-select>

在你的 .ts 文件中只需声明变量 itemId;

答案 4 :(得分:0)

根据我对 (ionChange)="optionsFn();" 的经验,我们可以使用 [(ngModel)]="selectVariable",稍后可以在 .ts 文件中轻松获取

答案 5 :(得分:-1)

进行以下更改后检查:

// html change

<ion-select [(ngModel)]="gaming" (change)="optionsFn();">
  <ion-option [value]="item" *ngFor="let item of options">{{item.name}} &nbsp;&nbsp;{{item.price}}</ion-option> 
</ion-select>

//。ts change

optionsFn() {
  console.log(this.gaming);
  let item = this.gaming;
  this.product_option_value_idOp = item.product_option_value_id;
  this.priceOp = item.price;
  this.salespriceOp = item.salesprice;
  this.quantityOp = item.quantity;
  this.skuOp = item.sku;
  this.nameOp = item.name;
}