Angular 里使用 FormControl 的步骤

简介: Angular 里使用 FormControl 的步骤
  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 t 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);
  }
相关文章
|
JSON 监控 JavaScript
Angular 里使用 FormControl 的步骤(二)
Angular 里使用 FormControl 的步骤
143 0
Angular 里使用 FormControl 的步骤(二)
|
JavaScript
Angular 里使用 FormControl 的步骤(一)
Angular 里使用 FormControl 的步骤
165 0
Angular 里使用 FormControl 的步骤(一)
|
20天前
|
缓存 JavaScript 前端开发
Angular 应用打包和部署
Angular 应用打包和部署
55 1
|
2月前
|
应用服务中间件 Java Maven
掌控视图的力量!深入解析 JSF 视图管理,揭秘视图生命周期的秘密,让你的应用更高效!
【8月更文挑战第31天】JavaServer Faces (JSF) 是一种强大的框架,用于管理 Web 应用程序的视图。本文通过具体案例介绍 JSF 视图管理的基础知识,包括创建、管理和销毁视图的过程。首先,在 Eclipse 中创建一个新 JSF 项目,并配置 Maven 依赖。接着,在 `WEB-INF` 目录下配置 `web.xml` 文件,设置 JSF servlet。
37 0
|
2月前
|
Java Spring
🔥JSF 与 Spring 强强联手:打造高效、灵活的 Web 应用新标杆!💪 你还不知道吗?
【8月更文挑战第31天】JavaServer Faces(JSF)与 Spring 框架是常用的 Java Web 技术。本文介绍如何整合两者,发挥各自优势,构建高效灵活的 Web 应用。首先通过 `web.xml` 和 `ContextLoaderListener` 配置 Spring 上下文,在 `applicationContext.xml` 定义 Bean。接着使用 `@Autowired` 将 Spring 管理的 Bean 注入到 JSF 管理的 Bean 中。
37 0
|
2月前
|
开发者 Java 开发框架
JSF与EJB,打造企业级应用的神器!让你的Web应用更加稳定、高效!
【8月更文挑战第31天】在现代企业级应用开发中,JSF(JavaServer Faces)与EJB(Enterprise JavaBeans)是两大核心技术。JSF作为一款基于Java的Web应用框架,以其丰富的UI组件和表单处理功能著称;EJB则专注于提供分布式事务处理及远程调用等企业级服务。两者的结合为企业应用带来了高效便捷的开发模式。下文将通过一个简单的示例展示如何利用JSF进行用户信息的输入与保存,并借助EJB实现相关业务逻辑。尽管这一组合具有明显优势,但在实际应用中还需考虑其局限性并作出合理选择。
42 0
|
2月前
|
开发者 安全 SQL
JSF安全卫士:打造铜墙铁壁,抵御Web攻击的钢铁防线!
【8月更文挑战第31天】在构建Web应用时,安全性至关重要。JavaServer Faces (JSF)作为流行的Java Web框架,需防范如XSS、CSRF及SQL注入等攻击。本文详细介绍了如何在JSF应用中实施安全措施,包括严格验证用户输入、使用安全编码实践、实施内容安全策略(CSP)及使用CSRF tokens等。通过示例代码和最佳实践,帮助开发者构建更安全的应用,保护用户数据和系统资源。
39 0
|
2月前
|
容器 iOS开发 Linux
震惊!Uno Platform 响应式 UI 构建秘籍大公开!从布局容器到自适应设计,带你轻松打造跨平台完美界面
【8月更文挑战第31天】Uno Platform 是一款强大的跨平台应用开发框架,支持 Web、桌面(Windows、macOS、Linux)及移动(iOS、Android)等平台,仅需单一代码库。本文分享了四个构建响应式用户界面的最佳实践:利用布局容器(如 Grid)适配不同屏幕尺寸;采用自适应布局调整 UI;使用媒体查询定制样式;遵循响应式设计原则确保 UI 元素自适应调整。通过这些方法,开发者可以为用户提供一致且优秀的多设备体验。
47 0
|
2月前
|
开发者 Windows Android开发
跨平台开发新选择:揭秘Uno Platform与.NET MAUI优劣对比,帮你找到最适合的框架,告别选择困难症!
【8月更文挑战第31天】本文对比了备受关注的跨平台开发框架Uno Platform与.NET MAUI的特点、优势及适用场景。Uno Platform基于WebAssembly和WebGL技术,支持Windows、iOS、Android及Web平台,而.NET MAUI由微软推出,旨在统一多种UI框架,支持Windows、iOS和Android。两者均采用C#和XAML进行开发,但在性能、平台支持及社区生态方面存在差异。Uno Platform在Web应用方面表现出色,但性能略逊于原生应用;.NET MAUI则接近原生性能,但不支持Web平台。开发者应根据具体需求选择合适的框架。
64 0
下一篇
无影云桌面