Angular 里使用嵌套 Form 的步骤

简介: Angular 里使用嵌套 Form 的步骤

我们可以在这个 FormGroup 构造函数的属性里,再增添一个类型为 FormGroup 的实例,形成嵌套的 form:

image.png

image.png

42.png

每一次显式调用 new 创建 FormGroupFormControl 实例显得很繁琐。其实我们可以使用 FormBuilder 通过工厂模式创建。

profileForm = this.fb.group({
    firstName: ['Jerry'],
    lastName: ['LastName'],
    address: this.fb.group({
      street: [''],
      city: ['']
    }),
  });

image.png

效果:

image.png


冒号后面的参数类型是 JSON 数组,第一个参数为默认的初始值,第二个参数为 validator,使用例子如下:

image.png

lastName 没有维护值时,整个 form 处于 ng-invalid 状态,submit 按钮无法点击。

43.png

嵌套 group 的 status 状态会冒泡到父 form.

可以通过 FormGroup.status 直接访问其状态。

44.png

this.profileForm.valueChanges.subscribe(
      value => {
        console.log('group value: ', value, ' status: ', 
        this.profileForm.status);
      }
    );

image.png

如果我们事先不知道待创建的 form 控件实例的准确数目,使用动态控件是一个不错的选择。所谓动态控件,即我们不需要为每一个控件显式指定 key.

一个实际例子:

aliases: this.fb.array([
    this.fb.control('')
  ])

image.png

创建一个 getter 访问器,通过代码的方式获得上图创建的动态控件:

get aliases() {
  return this.profileForm.get('aliases') as FormArray;
}

因为 this.profileForm.get('aliases') 返回的控件的类型是抽象数据类型

AbstractControl,所以你要为该方法提供一个显式的类型声明来访问 FormArray 特有的语法。

动态添加匿名组件 的方法:

addAlias() {
    this.aliases.push(this.fb.control(''));
  }

image.png

<div formArrayName="aliases">
        <h2>Aliases</h2>
        <button (click)="addAlias()" type="button">+ Add another alias</button>
        <div *ngFor="let alias of aliases.controls; let i=index">
          <!-- The repeated alias template -->
          <label for="alias-{{ i }}">Alias:</label>
          <input id="alias-{{ i }}" type="text" [formControlName]="i">
        </div>
      </div>

最后的效果:

image.png

这些匿名控件的值,通过如下方式打印出来:

45.png

onSubmit(){
    console.warn(this.profileForm.value);
  }

通过 formArrayNameformControlName 给这些匿名控件赋予了索引值,这样可以通过索引访问控件中的内容:

image.png

目录
相关文章
|
JavaScript 前端开发 API
让Angular自定义组件支持form表单验证
让Angular自定义组件支持form表单验证
160 0
|
JavaScript
Angular Form (响应式Form) 学习笔记
Angular Form (响应式Form) 学习笔记
193 0
Angular Form (响应式Form) 学习笔记
Angular Reactive Form 的一个具体使用例子
Angular Reactive Form 的一个具体使用例子
Angular Reactive Form 的一个具体使用例子
|
JavaScript 测试技术 API
Angular form学习笔记:Angular两种实现form的方式
Angular form学习笔记:Angular两种实现form的方式
282 0
Angular form学习笔记:Angular两种实现form的方式
|
JavaScript
Angular form控件的shadow DOM
Angular form控件的shadow DOM
102 0
Angular form控件的shadow DOM
Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机
Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机
145 0
Angular form控件原生HTML代码里ng-reflect-form属性和其值的生成时机
Angular form学习笔记
Angular form学习笔记
108 0
Angular form学习笔记