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,使用例子如下:
当 lastName 没有维护值时,整个 form 处于 ng-invalid 状态,submit 按钮无法点击。
嵌套 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')
返回的控件的类型是抽象数据类型 AbstractControl,所以你要为该方法提供一个显式的类型声明来访问 FormArray 特有的语法。
动态添加匿名组件 的方法:
addAlias() { this.aliases.push(this.fb.control('')); }
<div formArrayName="aliases"> <h2>Aliases</h2> <button (click)="addAlias()" type="button">+ Add another alias</button> <div *ngFor="let alias of aliases.controls; let i=index"> <!-- The repeated alias template --> <label for="alias-{{ i }}">Alias:</label> <input id="alias-{{ i }}" type="text" [formControlName]="i"> </div> </div>
最后的效果:
这些匿名控件的值,通过如下方式打印出来:
onSubmit(){ console.warn(this.profileForm.value); }
通过 formArrayName 和 formControlName 给这些匿名控件赋予了索引值,这样可以通过索引访问控件中的内容:
总结
到此这篇关于Angular中使用嵌套Form的文章就介绍到这了,更多相关Angular使用嵌套Form内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
ionic3+Angular4实现接口请求及本地json文件读取示例
本篇文章主要介绍了ionic3+Angular4实现接口请求及本地json文件读取示例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-10-10AngularJS模糊查询功能实现代码(过滤内容下拉菜单排序过滤敏感字符验证判断后添加表格信息)
最近做项目遇到这样的需求,要求添加球员的功能,具体样式没做具体要求,下面小编给大家带来了AngularJS模糊查询功能实现代码(过滤内容下拉菜单排序过滤敏感字符验证判断后添加表格信息),感兴趣的朋友一起看看吧2017-10-10AngularJS ng-bind-template 指令详解
本文注意介绍AngularJS ng-bind-template 指令,这里把相关资料整理了一下,并附实例代码,有需要的小伙伴可以参考下2016-07-07AngularJS中的$watch(),$digest()和$apply()区分
这篇文章主要介绍了AngularJS中的$watch(),$digest()和$apply()区分,感兴趣的朋友可以参考一下2016-04-04Angular实现类似博客评论的递归显示及获取回复评论的数据
这篇文章主要给大家介绍了关于Angular如何实现类似博客评论的递归显示及获取回复评论的数据的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。2017-11-11
最新评论