具有角反应形式的离子无线电组

时间:2017-12-23 00:46:35

标签: ionic-framework ionic3 angular-reactive-forms

我正在使用Ionic的项目,需要使用Angular 5中的反应形式。我需要允许用户选择语言偏好,并且我使用无线电组和离子 - 收音机,但当我对表格进行更改时,我正在

ERROR Error: There is no FormControl instance attached to form control element with name: 'preferredLanguage'

这是我的模板,其格式为

<ion-header>
  <ion-navbar>
    <ion-title>User Profile</ion-title>
  </ion-navbar>
</ion-header>

<ion-content padding>
  <form *ngIf="user" [formGroup]="profileForm" (ngSubmit)="saveUser()">
      <ion-item>
        <ion-label>Display Name</ion-label>
        <ion-input type="text" formControlName="displayName"></ion-input>
      </ion-item>
      <ion-item>
        <ion-label>First Name</ion-label>
        <ion-input type="text" formControlName="firstName"></ion-input>
      </ion-item>
      <ion-item>
        <ion-label>Last Name</ion-label>
        <ion-input type="text" formControlName="lastName"></ion-input>
      </ion-item>
      <ion-item>
        <ion-label>Email</ion-label>
        <ion-input type="text" formControlName="email"></ion-input>
      </ion-item>
      <ion-item>
        <ion-label>Street</ion-label>
        <ion-input type="text" formControlName="street"></ion-input>
      </ion-item>
      <ion-item>
        <ion-label>City</ion-label>
        <ion-input type="text" formControlName="city"></ion-input>
      </ion-item>
      <ion-item>
        <ion-label>State</ion-label>
        <ion-input type="text" formControlName="state"></ion-input>
      </ion-item>
      <ion-item>
        <ion-label>Zip Code</ion-label>
        <ion-input type="text" formControlName="zip"></ion-input>
      </ion-item>
      <ion-list radio-group formControlName="preferredLanguage">
        <ion-list-header>
          Select Preferred Language
        </ion-list-header>
        <ion-item>
          <ion-label>English</ion-label>
          <ion-radio value="en-US"></ion-radio>
        </ion-item>
        <ion-item>
          <ion-label>Spanish</ion-label>
          <ion-radio value="es-US"></ion-radio>
        </ion-item>
      </ion-list>
    <button type="submit" ion-button>Submit Profile</button>
  </form>
</ion-content>

这是初始化表单的方法

initProfileForm() {
    this.profileForm = this.formBuilder.group({
      displayName: [this.user.profile.displayName, Validators.required],
      firstName: [this.user.profile.firstName, Validators.required],
      lastName: [this.user.profile.lastName, Validators.required],
      email: [this.user.profile.email, Validators.required],
      street: [this.user.profile.street, Validators.required],
      city: [this.user.profile.city, Validators.required],
      state: [this.user.profile.state, Validators.required],
      zip: [this.user.profile.zip, Validators.required] ,
      preferredLanguage: [this.user.profile.preferredLanguage, 
Validators.required]
    });
  }

有没有其他人有这个问题,你是如何解决的?

3 个答案:

答案 0 :(得分:1)

我最终想出了一个解决方案。这篇博客帮我提出了一个答案:https://robferguson.org/blog/2017/11/19/ionic-3-and-forms/显然,无线电组不能使用formControlName,所以我最终使用了这个:

  <ion-list radio-group [formControl]="profileForm.controls['preferredLanguage']">
    <ion-list-header>
      Select Preferred Language
    </ion-list-header>
    <ion-item>
      <ion-label>English</ion-label>
      <ion-radio value="en-US"></ion-radio>
    </ion-item>
    <ion-item>
      <ion-label>Spanish</ion-label>
      <ion-radio value="es-US"></ion-radio>
    </ion-item>
  </ion-list>

这解决了问题,因此不再出现错误。

答案 1 :(得分:1)

get preferredLanguage() {
  return this.profileForm.get('preferredLanguage').value;
}

set preferredLanguage(ev: CustomEvent) {
  this.profileForm.get('preferredLanguage').patchValue(ev.detail.value);
}
<ion-radio-group [value]="preferredLanguage" (ionChange)="preferredLanguage = $event">
  <ion-item>
    <ion-label>English</ion-label>
    <ion-radio value="en-US"></ion-radio>
  </ion-item>
  <ion-item>
    <ion-label>Spanish</ion-label>
    <ion-radio value="es-US"></ion-radio>
  </ion-item>
</ion-radio-group>

答案 2 :(得分:0)

在HTML代码中进行一些修改:

    <ion-item>
      <ion-label>English</ion-label>
      <ion-radio value="en-US" formControlName="preferredLanguage"></ion-radio>
    </ion-item>
    <ion-item>
      <ion-label>Spanish</ion-label>
      <ion-radio value="es-US" formControlName="preferredLanguage"></ion-radio>
    </ion-item>

所以基本上不是在父母身上使用它而是为每个单选按钮单独使用它。这对我有用。

希望它有所帮助!

相关问题