Angular-动态FormArray控件不能被验证
创始人
2024-10-21 03:30:50
0

在Angular中,如果希望动态地添加和删除表单中的控件,可以使用FormArray。但是,如果FormArray中的控件没有被正确验证,那么在提交表单时可能会遇到问题。

解决这个问题的方法是使用控件本身的valid属性来验证FormArray中的控件。以下是一个示例代码:

myForm: FormGroup;

ngOnInit() { this.myForm = new FormGroup({ myArray: new FormArray([]) }); }

addControl() { const control = new FormControl('', Validators.required); (this.myForm.controls['myArray']).push(control); }

removeControl(index: number) { (this.myForm.controls['myArray']).removeAt(index); }

onSubmit() { (this.myForm.controls['myArray']).controls.forEach(control => { if (control instanceof FormGroup) { (control).controls.forEach(c => { c.markAsDirty(); // 标记控件为已修改 c.updateValueAndValidity(); // 更新控件的值和验证状态 }); } else { control.markAsDirty(); // 标记控件为已修改 control.updateValueAndValidity(); // 更新控件的值和验证状态 } });

// 如果表单的验证通过,则提交表单 if (this.myForm.valid) { // 执行提交表单的操作 } }

在上面的示例中,addControl方法用于添加一个新的FormControl,removeControl方法用于删除指定索引的控件。onSubmit方法用于提交表单,并验证FormArray中的每个控件是否已被修改和验证。如果表单的验证通过,则可以执行提交表单的操作。

相关内容

热门资讯

据目击者称!拼三张自建房软件!... 据目击者称!拼三张自建房软件!本来有挂辅助挂(真是有挂)-哔哩哔哩1、每一步都需要思考,不同水平的挑...
截至发稿!微友辅助器免费下载!... 截至发稿!微友辅助器免费下载!好像是有辅助安装(真实有挂)-哔哩哔哩一、微友辅助器免费下载可以开透视...
相较于以往!天天微友辅助器!竟... 相较于以往!天天微友辅助器!竟然真的是有辅助神器(有挂存在)-哔哩哔哩1、操作简单,无需天天微友辅助...
据统计!阿拉斗牌脚本!竟然是真... 据统计!阿拉斗牌脚本!竟然是真的辅助下载(有挂细节)-哔哩哔哩阿拉斗牌脚本破解侠是真的助透视。每个模...
值得注意的是!决战十水三修改器... 值得注意的是!决战十水三修改器!确实真的有辅助下载(有挂助手)-哔哩哔哩1)决战十水三修改器辅助插件...
近年来!逍遥湖北微信辅助!本来... 近年来!逍遥湖北微信辅助!本来是有辅助平台(新版有挂)-哔哩哔哩1、逍遥湖北微信辅助免费脚本咨询教程...
经调查!传送屋万能辅助器!切实... 经调查!传送屋万能辅助器!切实真的有辅助下载(新版有挂)-哔哩哔哩1、首先打开传送屋万能辅助器辅助器...
现有说明如下!广东雀神智能插件... 现有说明如下!广东雀神智能插件是真有挂!原来是真的辅助app(竟然有挂)-哔哩哔哩在进入广东雀神智能...
此事引发广泛关注!指尖四川脚本... 此事引发广泛关注!指尖四川脚本!果然存在有辅助软件(有挂辅助)-哔哩哔哩1、指尖四川脚本透视辅助软件...
据悉!德州之星插件!确实存在有... 据悉!德州之星插件!确实存在有辅助修改器(有挂教学)-哔哩哔哩1.德州之星插件 选牌创建新账号,点击...