首页 > 解决方案 > Angular - patchValue FormControl

问题描述

我有我在方法 saveConvention 中调用的 formGroup 波纹管,我想获取组合同并在 createConvention 服务中编辑 formControl conventionId,我尝试使用下面提到的方法但是当我尝试显示时,conventionId 始终为空

  this.conventionForm = this.fb.group({
        shortname: fb.control(null, Validators.required),
        fullname: fb.control(null, Validators.required),
        contract: this.fb.group({
            conventionId: fb.control(null),
            signatureProvides: fb.control(null, Validators.required)
        })
    });


public saveConvention(data: FormGroup): void {
    let currentData: FormGroup = data;

    let formControlContract: AbstractControl = currentData.get('contract');

    data.removeControl('contract');
    this.conventionService.createConvention(data.value)
        .catch(err => {})
        .subscribe(res => formControlContract.patchValue({ conventionId: res.id }) );

   console.log(formControlContract.value);

   this.contractBenefitPartnerService.createContract(formControlContract.value)
         .catch(err => {}).subscribe(res => {});            
  }

标签: angularangular-forms

解决方案


使用 patchValue 后需要使用updateValueAndValidity才能生效。

this.conventionService.createConvention(data.value)
    .catch(err => {})
    .subscribe(res => {
       formControlContract.patchValue({ conventionId: res.id }) 
       formControlContract.updateValueAndValidity();
    }
);

推荐阅读