Angular动态FormArray使用CVA,子验证未传播。
创始人
2024-10-24 14:31:12
0

在Angular中,可以使用ControlValueAccessor(CVA)来创建自定义表单控件,并实现表单验证。当使用动态FormArray时,可能会遇到子验证未传播的问题。下面是一个解决方法的示例代码:

首先,创建一个自定义表单控件,并实现ControlValueAccessor接口:

import { Component, forwardRef, Provider } from '@angular/core';
import { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';

const CUSTOM_VALUE_ACCESSOR: Provider = {
  provide: NG_VALUE_ACCESSOR,
  useExisting: forwardRef(() => CustomFormComponent),
  multi: true
};

@Component({
  selector: 'app-custom-form',
  template: `
    
`, providers: [CUSTOM_VALUE_ACCESSOR] }) export class CustomFormComponent implements ControlValueAccessor { formArray: FormArray; // Implement ControlValueAccessor methods writeValue(value: any): void { if (value) { this.formArray = new FormArray(value); } else { this.formArray = new FormArray([]); } } registerOnChange(fn: any): void { this.formArray.valueChanges.subscribe(fn); } registerOnTouched(fn: any): void {} setDisabledState(isDisabled: boolean): void {} }

然后,在父组件中使用该自定义表单控件,并传入动态的FormArray:

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

@Component({
  selector: 'app-parent-component',
  template: `
    
` }) export class ParentComponent { form: FormGroup; constructor(private fb: FormBuilder) { this.form = this.fb.group({ customFormArray: this.fb.array([]) }); } // Add a new control to the FormArray addControl(): void { const customFormArray = this.form.get('customFormArray') as FormArray; customFormArray.push(this.fb.control('')); } }

在父组件中,每当添加新的控件时,调用addControl()方法。这样,动态的FormArray会传播到自定义表单控件中,子验证也会正确工作。

希望这个示例能够帮助你解决Angular动态FormArray使用CVA时子验证未传播的问题。

相关内容

热门资讯

第七次性晓得!智星德州插件“曝... 第七次性晓得!智星德州插件“曝光开挂辅助神器”1、超多福利:超高返利,海量正版游戏,智星德州插件系统...
两次性黑科技!中至上饶麻将有挂... 两次性黑科技!中至上饶麻将有挂开挂“必备开挂辅助攻略”;1、上手简单,内置详细流程视频教学,新手小白...
1次性精通!wepoker私人... 1次性精通!wepoker私人局可以透视“推荐开挂辅助神器”1、游戏颠覆性的策略玩法,独创攻略技巧玩...
第4次性了解!一起宁德钓蟹技巧... 第4次性了解!一起宁德钓蟹技巧“总结开挂辅助器”1)一起宁德钓蟹技巧辅助挂:进一步探索一起宁德钓蟹技...
9次性发现!微信微乐小程序修改... 9次性发现!微信微乐小程序修改器“推荐开挂辅助app”运微信微乐小程序修改器辅助工具,进入游戏界面。...
第3次性普及!微信新众游辅助“... 第3次性普及!微信新众游辅助“科普开挂辅助攻略”1、首先打开微信新众游辅助最新版本,在微信新众游辅助...
7次性辅助挂!开心泉州小程序辅... 7次性辅助挂!开心泉州小程序辅助哪里查看“外挂开挂辅助挂”1)开心泉州小程序辅助哪里查看辅助挂:进一...
第6次性了解!新天道破解版“外... 第6次性了解!新天道破解版“外挂开挂辅助方法”1、每一步都需要思考,不同水平的挑战会更加具有挑战性,...
第八次性体悟!闲来透视辅助器最... 第八次性体悟!闲来透视辅助器最新版“了解开挂辅助方法”1)闲来透视辅助器最新版辅助挂:进一步探索闲来...
第三次性黑科技!决战卡五星开挂... 第三次性黑科技!决战卡五星开挂方法“详情开挂辅助挂”1、完成决战卡五星开挂方法的残局,帮助玩家取得所...