我有一个关于角度的表单,它允许根据下拉列表中选择的值显示输入。
下面是我的代码示例:
(如果选择了两个,则会出现一个输入)
https://stackblitz.com/edit/angular-fqkfyx
如果我离开[formgroup]=“usform”,输入显示将不起作用。另一方面,如果我删除标记表单的[formgroup]=“usform”,我的代码将按我的意愿工作。所以这个问题与[formgroup]=“usform”有关
我的HTML:

 <div class="offset-md-2">
  <form [formGroup]="usForm">
    <div class="div-champs">
      <p id="champs">Type
        <span id="required">*</span>
      </p>
      <div class="select-style ">
          <select [(ngModel)]="selectedOption" name="type">
              <option style="display:none">
              <option [value]="o.name" *ngFor="let o of options">
                {{o.name}}
              </option>
          </select>
      </div>
    </div>
    <p id="champs" *ngIf="selectedOption == 'two'">Appears
      <input type="appears" class="form-control" name="appears">
    </p>
  </form>
</div>

我的组件.ts:
import { Component, OnInit } from '@angular/core';

import { FormGroup, FormBuilder } from '@angular/forms';

@Component({
  selector: 'app-create-us',
  templateUrl: './create-us.component.html',
  styleUrls: ['./create-us.component.css']
})
export class CreateUsComponent implements OnInit {

  public usForm: FormGroup;
  public selectedOption: string;

  constructor(private fb: FormBuilder) {
  }

  ngOnInit() {
    this.createForm();
  }

  createForm() {
    this.usForm = this.fb.group({
      'type': [null, ],
      'appears': [null, ],
    });
  }

  options = [
    { name: 'first', value: 1 },
    { name: 'two', value: 2 }
  ];
}

我简化了我的问题,实际上它是一个大的形式,有十几个输入
我需要你的帮助,提前谢谢
当做,
瓦伦丁

最佳答案

您应该使用formControlName而不是[(ngModel)]
相比之下,你应该与usForm.value.type而不是selectedValue进行比较。
试试看:

<div class="offset-md-2">
  <form [formGroup]="usForm">
    <div class="div-champs">
      <p id="champs">Type
        <span id="required">*</span>
      </p>
      <div class="select-style ">
          <select formControlName="type" name="type">
              <option style="display:none">
              <option [value]="o.name" *ngFor="let o of options">
                {{o.name}}
              </option>
          </select>
      </div>
    </div>
    <p id="champs" *ngIf="usForm.value.type == 'two'">Appears
      <input type="appears" class="form-control" name="appears">
    </p>
  </form>
</div>

这是给你的裁判的Sample StackBlitz

09-25 18:32