Angular 里使用 FormControl 的步骤(二)

简介: Angular 里使用 FormControl 的步骤

如何响应用户输入

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

效果:

image.png从调用栈发现,仍然是 executeListenerWithErrorHandling

9.png

image.png

通过 EventEmitter 发送更新:

11.png

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

12.png

如何使用表单组 form group

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

image.png

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

image.png

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>

13.png

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

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

image.png

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

使用 setValue 修改 group 的值:

image.png

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

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

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

14.png

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



目录
相关文章
|
7月前
|
JSON 监控 JavaScript
Angular 里使用 FormControl 的步骤
Angular 里使用 FormControl 的步骤
26 0
|
JavaScript
Angular 里使用 FormControl 的步骤(一)
Angular 里使用 FormControl 的步骤
146 0
Angular 里使用 FormControl 的步骤(一)
|
2月前
|
设计模式 JavaScript 前端开发
什么是 Angular 应用里的 Custom provider
什么是 Angular 应用里的 Custom provider
30 2
|
3月前
Angular 应用里异步打开对话框的技术实现
Angular 应用里异步打开对话框的技术实现
22 0
|
17天前
|
存储 JavaScript 前端开发
Angular 应用 node_modules 子文件夹 @types 的作用介绍
Angular 应用 node_modules 子文件夹 @types 的作用介绍
12 1
|
3月前
|
Web App开发 UED 开发者
谈谈企业级 Angular 应用的二次开发 - 基于 Angular Component 替换的 Extensibility 支持案例介绍
谈谈企业级 Angular 应用的二次开发 - 基于 Angular Component 替换的 Extensibility 支持案例介绍
40 1
|
1月前
|
开发框架 前端开发 安全
Angular:构建现代Web应用的终极选择
Angular:构建现代Web应用的终极选择
23 0
|
2月前
|
Go
Mac安装Angular并部署运行应用
Mac安装Angular并部署运行应用
|
3月前
|
缓存 前端开发 JavaScript
Angular Service Worker 在 PWA 应用 HTTP 交互中扮演的角色
Angular Service Worker 在 PWA 应用 HTTP 交互中扮演的角色
45 0

热门文章

最新文章