继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

响应式表单之操作表单

为爱心太软
关注TA
已关注
手记 170
粉丝 1.4万
获赞 860

Get() 方法

根据名称(或者路径)获取子表单或字段。

例子:

// form.component.ts

ngOnInit() {

  this.myGroup = this.fb.group({
    name:'吴蕾',
    childGroup:this.fb.group({
      sex:'女'
    })
    
  });

  // 根据名称获取字段
  const nameControl = this.myGroup.get('name'); 

  // 根据路径获取子表单的字段
  const sexControl = this.myGroup.get('childGroup.sex');
  // 下面的写法也可以:
  // const sexControl2 = this.myGroup.get(['childGroup', 'sex']);

  console.log(nameControl); // formControl 对象
  console.log(sexControl); // fFormControl 对象

}

Value 属性

对于 FormControl,指向当前字段的值。

例子:

// form.component.ts

ngOnInit() {

  this.myGroup = this.fb.group({
    name:'吴蕾',
    age:'20',
    sex:'1'
  });

  // 获取字段值
  const nameControlValue = this.myGroup.get('name')?.value; 

  console.log(nameControlValue); // 吴蕾

}

对于 FormGroup,指向键值对组成的对象。

例子:

// form.component.ts

ngOnInit() {

  this.myGroup = this.fb.group({
    name:'吴蕾',
    age:'20',
    sex:'1'
  });

  // 获取表单对象
  const nameGroupValue = this.myGroup?.value; 

  console.log(nameGroupValue); // {name: '吴蕾', age: '20', sex: '1'}

}

ValueChanges() 方法

对于 FormControl,监听单个字段值的变化,并返回最新值。

例子:

图片描述

// form.component.ts

ngOnInit() {

  this.myGroup = this.fb.group({
    name:'吴蕾',
    age:'20',
    sex:'1'
  });

    // 监听字段值的变化
  this.myGroup.get('name')?.valueChanges.subscribe((value: string)=>{

    // 参数 value 指向最新值
    console.log(value); // 张三

  });

}

对于 FormGroup,监听组内每个字段值的变化,并返回最新的对象。

例子:

图片描述

// form.component.ts

ngOnInit() {

  this.myGroup = this.fb.group({
    name:'吴蕾',
    age:'20',
    sex:'1'
  });

    // 监听表单中每个字段值的变化
  this.myGroup?.valueChanges.subscribe((value: string)=>{

    // 参数 value 指向最新键值对组成的对象
    console.log(value); // {name: '张三', age: '30', sex: '0'}

  });

}

SetValue() 与 PatchValue() 方法

对于 FormControl,SetValue() 与 PatchValue() 都可以为字段设置新值,用法一致。

例子:

图片描述

// form.component.ts

ngOnInit() {

  this.myGroup = this.fb.group({
    name:'吴蕾',
    age:'20',
    sex:'1'
  });

}

clear(){
  // 清空 name 字段值
  this.myGroup.get('name')?.setValue('');
  // this.myGroup.get('name')?.patchValue('');
  
  console.log(this.myGroup.value); // {name: '', age: '20', sex: '1'}
}

对于 FormGroup,SetValue() 必须严格遵循表单的结构,并整体性替换为新对象,而 PatchValue() 可以对任意键值对进行替换。

例子:

图片描述

// form.component.ts

ngOnInit() {

  this.myGroup = this.fb.group({
    name:'吴蕾',
    age:'20',
    sex:'1'
  });

}

clear(){
  // setValue() 整体性替换为新对象,不可以缺少任何字段
  // this.myGroup?.setValue({
  //   name:'',
  //   age:'20',
  //   sex:'0'
  // });

  // patchValue() 只替换我们需要替换的键值对即可
  this.myGroup?.patchValue({
    name:'',
    sex:'0'
  });

  console.log(this.myGroup.value); // {name: '', age: '20', sex: '0'}
}

*综上所述,在实际工作中,通常使用 FormControl 的 SetValue() 方法为字段设置新值,使用 FormGroup 的 PatchValue() 方法对键值对进行替换。

Disable() 与 Enable() 方法

对于 FormControl,Disable() 与 Enable() 分别对应着禁用和启用单个字段。

例子:

图片描述

// form.component.ts

ngOnInit() {

  this.myGroup = this.fb.group({
    name:'吴蕾',
    age:'20',
    sex:'1'
  });

}

// 禁用函数
disableFn(){
  this.myGroup.get('name')?.disable();
  console.log(this.myGroup.value); // {age: '20', sex: '1'}
}

// 启用函数
enableFn(){
  this.myGroup.get('name')?.enable();
  console.log(this.myGroup.value); // {name: '吴蕾', age: '20', sex: '1'}
}

*值得注意的是,当我们禁用某个字段时,this.myGroup 对象里也排除了这个键值对,不仅如此,该字段的验证器也会被忽略。

对于 FormGroup,Disable() 与 Enable() 分别对应着禁用和启用整个表单。

例子:

图片描述

// form.component.ts

ngOnInit() {

  this.myGroup = this.fb.group({
    name:'吴蕾',
    age:'20',
    sex:'1'
  });

}

// 禁用函数
disableFn(){
  this.myGroup?.disable();
  console.log(this.myGroup.value); // {name: '吴蕾', age: '20', sex: '1'}
}

// 启用函数
enableFn(){
  this.myGroup?.enable();
  console.log(this.myGroup.value); // {name: '吴蕾', age: '20', sex: '1'}
}

事件发射器

FormControl 和 FormGroup 都带有事件发射器( emitEvent ),当我们调用 SetValue()、PatchValue()、Disable()、Enable() 等方法时,ValueChanges() 就会监听到这个发射器,并执行相应的程序。

例子:

图片描述

// form.component.ts

ngOnInit() {

  this.myGroup = this.fb.group({
    name:'吴蕾',
    age:'20',
    sex:'1'
  });

  // 监听到 name 发生变换,修改 age 和 sex 的值
  this.myGroup.get('name')?.valueChanges.subscribe((value:string)=>{
    this.myGroup?.patchValue({
      age:'',
      sex:'0'
    });
  });

}

// 清空姓名函数
clearName(){
  this.myGroup.get('name')?.setValue('');
}

如果我们不想让 ValueChanges() 监听到这个发射器,可以设置 emitEvent 为 false。

例子:

图片描述

// form.component.ts

ngOnInit() {

  this.myGroup = this.fb.group({
    name:'吴蕾',
    age:'20',
    sex:'1'
  });

  this.myGroup.get('name')?.valueChanges.subscribe((value:string)=>{
    this.myGroup?.patchValue({
      age:'',
      sex:'0'
    });
  });

}

// 清空姓名函数
clearName(){
  this.myGroup.get('name')?.setValue('', { emitEvent: false });
}

end

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP