Angular 里使用 FormControl 的步骤

网友投稿 258 2022-09-28

Angular 里使用 FormControl 的步骤

导入​​FormControl​​:

import { FormControl } from '@angular/forms';

在 Component 里创建一个 ​​name​​​ 实例,类型为 ​​FormControl​​:

name = new FormControl('Jerry');

通过构造函数 ​​FormControl​​ 设置初始值。

在 HTML 文件里,将 element 同 Component 的​​name​​ 属性建立绑定关系:

这之后 Component name 属性的值,就会自动传递到 HTML element 里:

这样,表单控件和 DOM 元素就可以互相通讯了:视图会反映模型的变化,模型也会反映视图中的变化。

使用 ​​.value​​ 可以访问 FormControl 实例的值:

显示控件的值: {{ name.value }}

如何使用 ​​setValue​​ 修改 FormControl 的值

updateName() { this.name.setValue('Nancy');}

值变为 nancy:

在 event handler 里看到 click 响应事件在 ​​zone.js​​ 里的统一处理:

最终在 ​​core.js​​​ 里调用 ​​executeListenerWithErrorHandling​​:

执行 setValue:

如何响应用户输入

constructor(){ this.name.valueChanges.subscribe(selectedValue => { console.log('value changed: ', selectedValue); }) }

效果:

从调用栈发现,仍然是 ​​executeListenerWithErrorHandling​​:

通过 ​​EventEmitter​​ 发送更新:

​​ng-untouched ng-pristine ng-valid​​ 这三个 class 什么时候赋的值?

ng-untouched The field has not been touched yetng-pristine The field has not been modified yetng-valid The field content is valid

如何使用表单组 ​​form group​​

在 Component 里创建一个类型为 ​​FormGroup​​ 的属性。

其构造函数是一个 json 对象,property 的类型为 ​​FormControl​​.

FormGroup 也能使用 ​​setValue​​ 等方法。

这个表单组还能跟踪其中每个控件的状态及其变化,所以如果其中的某个控件的状态或值变化了,父控件也会发出一次新的状态变更或值变更事件。

如何把 FormGroup 属性绑定到 HTML 文件中:

由 ​​FormControlName​​ 指令提供的 ​​formControlName​​ 属性把每个输入框和 ​​FormGroup​​ 中定义的​​表单控件​​绑定起来。

FormGroup 组内数据一样可以通过 ​​valueChanges​​ 被监控:

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

使用 ​​setValue​​ 修改 group 的值:

this.profileForm.setValue( { firstName: 'Tom', lastName: "Tom1" } );

往表单的底部添加一个 button,用于触发表单提交。

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

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

上一篇:使用Java实现大小写转换实例代码
下一篇:智汇华云 | flashcache原理及实践
相关文章

 发表评论

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