Angular 里使用 FormControl 的步骤

举报
汪子熙 发表于 2022/11/06 21:39:16 2022/11/06
【摘要】 导入 FormControl:import { FormControl } from '@angular/forms';在 Component 里创建一个 name 实例,类型为 FormControl:name = new FormControl('Jerry');通过构造函数 FormControl 设置初始值。在 HTML 文件里,将 element 同 Component 的 nam...
  1. 导入 FormControl:
import { FormControl } from '@angular/forms';

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

name = new FormControl('Jerry');

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

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

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

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

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

<label for="name">Name: </label>
<input id="name" type="text" [formControl]="name">

<p>显示控件的值: {{ name.value }}</p>

如何使用 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 yet
  • ng-pristine The field has not been modified yet
  • ng-valid The field content is valid

如何使用表单组 form group

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

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

FormGroup 也能使用 setValue 等方法。

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

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

<form [formGroup]="profileForm">

  <label for="first-name">First Name: </label>
  <input id="first-name" type="text" formControlName="firstName">

  <label for="last-name">Last Name: </label>
  <input id="last-name" type="text" formControlName="lastName">

</form>

FormControlName 指令提供的 formControlName 属性把每个输入框和 FormGroup 中定义的表单控件绑定起来。
FormGroup 组内数据一样可以通过 valueChanges 被监控:

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

使用 setValue 修改 group 的值:

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

form 标签所发出的 submit 事件是内置 DOM 事件,通过点击类型为 submit 的按钮可以触发本事件。这还让用户可以用回车键来提交填完的表单。

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

onSubmit(){
    console.warn(this.profileForm.value);
  }
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。