Angular 里使用嵌套 Form 的步骤

网友投稿 301 2022-09-28

Angular 里使用嵌套 Form 的步骤

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

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

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

效果:

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

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

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

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

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

一个实际例子:

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

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

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

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

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

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

Aliases

最后的效果:

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

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

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

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:试图添加产品到 Spartacus 购物车时遇到错误消息 - This item was already in your cart
下一篇:使用Java实现大小写转换实例代码
相关文章

 发表评论

暂时没有评论,来抢沙发吧~