如何在离子无线电元件上使用ngModel?

时间:2016-03-18 17:19:01

标签: javascript ionic-framework angular ecmascript-6 ionic2

我试图在离子无线电元素上实现ngModel,但不知怎的,它不起作用。这是我的代码:

HTML

<ion-list radio-group>
    <ion-list-header>
        Unit
    </ion-list-header>

    <ion-item>
        <ion-label>Metric (kg)</ion-label>
        <ion-radio value="1" [(ngModel)]="unit"></ion-radio>
    </ion-item>

    <ion-item>
        <ion-label>Imperial (lbs)</ion-label>
        <ion-radio value="2" [(ngModel)]="unit"></ion-radio>
    </ion-item>
</ion-list>

的Javascript

import {Page} from 'ionic-angular';

@Page({
    templateUrl: 'build/pages/settings/settings.html'
})

export class Settings {
    constructor() {
        this.unit = 2;
    }
}

我已尝试在离子输入和离子选择上实现它,并且工作正常。我还尝试将directives: [FORM_DIRECTIVES]添加到我的@Page并添加了相应的导入,但这并没有解决问题。

有什么想法吗?

7 个答案:

答案 0 :(得分:24)

现在已重写语法,ngModel应放在ion-list&amp; radio-group只有一次。不需要在每个ion-radio元素上都有它们。

<ion-list radio-group [(ngModel)]="unit">
    <ion-list-header>
        Unit
    </ion-list-header>

    <ion-item>
        <ion-label>Metric (kg)</ion-label>
        <ion-radio value="1"></ion-radio>
    </ion-item>

    <ion-item>
        <ion-label>Imperial (lbs)</ion-label>
        <ion-radio value="2" ></ion-radio>
    </ion-item>
</ion-list>

有关更多信息,请访问ionic2 framework forum link

答案 1 :(得分:2)

它与Ionic 5兼容。

  <ion-radio-group value="answer">
       <ion-item *ngFor="let item of question?.answers">
           <ion-label> {{item.answer}} {{answer}}</ion-label>
           <ion-radio slot="start" color="tertiary" value="{{item.id}} 
                 (ionBlur)="saveAnswer(item.id)">
             </ion-radio>
        </ion-item>
   </ion-radio-group>

答案 2 :(得分:0)

您还必须在Ionic 5中更新以下代码。

this.unit = 2;  

this.unit = '2';  

总之,您不能使用整数变量作为ion-radio值。

如果要使用整数类型的单位,请参考以下代码。

this.options = [
  {
    label: 'Metric (kg)',
    value: 1
  },
  {
    label: 'Imperial (lbs)',
    value: 2
  }
];

.html代码中的

<ion-radio-group [(ngModel)]="unit">
  <ion-list-header>
    <ion-label>
      Unit
    </ion-label>
  </ion-list-header>
  <ion-item *ngFor="let opt of options">
    <ion-label>{{opt.label}}</ion-label>
    <ion-radio [value]="opt.value" slot="start"></ion-radio>
  </ion-item>
</ion-radio-group>

答案 3 :(得分:0)

从Ionic 4+开始,正确的税率是:

<ion-list>
<ion-radio-group [(ngModel)]="unit"> 
  <ion-list-header>
    Unit
  </ion-list-header>
    <ion-item>
      <ion-label>Metric (kg)</ion-label>
      <ion-radio value="1"></ion-radio>
    </ion-item>

    <ion-item>
      <ion-label>Imperial (lbs)</ion-label>
      <ion-radio value="2"></ion-radio>
    </ion-item>
  </ion-radio-group>
</ion-list>

答案 4 :(得分:0)

这是适用于离子5..testing且工作正常的

 <ion-list>
        <ion-radio-group  >
          <ion-list-header>
            <ion-label>{{'Drivers' | translate}}</ion-label>
          </ion-list-header>
          <ion-item *ngFor="let item of drivers" lines="none" (ionChange)="checkValue(item)">
            <ion-avatar slot="start">
              <img [src]="item.coverImage" />
            </ion-avatar>
            <ion-label>{{item.fullname}} <br>
              <p>{{'Distance' | translate}} : {{item.distance}}Km</p>
            </ion-label>
            <ion-radio [value]="item.id"></ion-radio>
          </ion-item>
        </ion-radio-group>
      </ion-list>

然后在您的控制器中,您可以像这样选择它

checkValue(value){

console.log(“返回”,值);

}

答案 5 :(得分:0)

这对我有用

 postData={
"gender":''

}

   <ion-list>
  <ion-radio-group value="Male" >
    <ion-list-header>
      <ion-label style="font-size:10px;">Gender</ion-label>
    </ion-list-header>
    
    <ion-item>
      <ion-label>Male</ion-label>
      <ion-radio slot="start" value="Male" (ionBlur)="postData.gender='Male'"></ion-radio>
    </ion-item>

    <ion-item>
      <ion-label>Female</ion-label>
      <ion-radio slot="start" value="Female" (ionBlur)="postData.gender='Female'"></ion-radio>
    </ion-item>

  </ion-radio-group>
</ion-list>

答案 6 :(得分:-1)

这在Ionic 5上对我有用                         

</ion-list-header>

  <ion-item>
    <ion-label>
        <ion-icon name="radio-button-off"></ion-icon>
        Circle
        </ion-label>

    <ion-radio value="1" ></ion-radio>
  </ion-item>
  <ion-item>
    <ion-label>
        <ion-icon name="square-outline"></ion-icon>
        Square
    </ion-label>
    <ion-radio value="2"></ion-radio>
  </ion-item>
  <ion-item>
    <ion-label>
        <ion-icon name="play"></ion-icon>
        Triangle
    </ion-label>
    <ion-radio value="3" ></ion-radio>
  </ion-item>
</ion-radio-group>