angular表单的使用实例

原文

https://www.jianshu.com/p/da1fd5396798

大纲

  1、模板驱动表单的创建
  2、响应式表单的创建
  3、模板驱动型表单的自定义指令
  4、响应式表单的自定义指令
  5、父组件向子组件传递表单控制
  6、代码素材

模板驱动表单的创建

//1、在根模块注入依赖模块
import { FormsModule }   from ‘@angular/forms‘;
//2、在模板中创建表单控件
<form>
  <div class="form-group">
    <label class="center-block">Name1:
      <input class="form-control">
    </label>
  </div>
  <div class="form-group">
    <label class="center-block">Age1:
      <input class="form-control">
    </label>
  </div>
</form>
//3、在模板中添加ngModel同步数据
//4、数据校验:模板型表单的数据校验是写在模板上的,
//将require、minlength等校验规则写在模板上,从而定义对应表单控件的校验规则
//5、表单的提交,可以通过提交被监控的表单的值来达到表单的提交
//6、可以自定义设置表单数据的校验

响应式表单的创建

//1、在根模块注入依赖模块,引入ReactiveFormsModule
import { ReactiveFormsModule } from ‘@angular/forms‘;
//2、在模板中创建form表单
//3、在组件中创建响应式表单控制器
ReactiveForm = new FormGroup({
    age: new FormControl(‘‘,[Validators.required])
});
//4、监控表单的值的变化
/*
a:数据模型的值的变化:这里同样需要ngModel来绑定数据模型和表单模型的值,
不过需要注意的是,如果用ngModel来绑定表单控件,
那么通过new FormControl设置的默认值可能就会被ngModel的默认值给覆盖了
b:表单模型的值的变化:可以通过监控{{ReactiveForm.value.age}}来监控值的变化
*/
//5、数据的校验
/*
  各个表单控件的数据的校验是需要通过FormControl来设置的,
  可以看到每个new FormControl后都可以对各个表单控件进行数据的校验。
*/
//6、表单的提交
/*
(ngSubmit)="onSubmit(user)"通过ngSumbit即可实现表单数据的提交,
user是表单的名字,即:[formGroup]="user"
*/
//7、可以自定义设置表单数据的校验

模板驱动型表单的自定义指令

  模板型表单校验需要通过模板中添加属性才可以添加验证,所以需要继承指令Directive,在Directive中定义元数据并添加一系列的自定义的表单校验规则。

/**
  equalCrk.direvtive.ts
  使用:
  <input name="nickName" id="nickName" [(ngModel)]=‘nickName‘ validateCrk>
  当输入的数据不是crk的时候,表单的校验是不会通过的
**/
import { Directive, forwardRef, Attribute } from ‘@angular/core‘;
import { NG_VALIDATORS, Validator, AbstractControl } from ‘@angular/forms‘;

@Directive({
  selector: ‘[validateCrk][ngModel]‘,
  providers: [
    {
      provide: NG_VALIDATORS,
      useExisting: forwardRef(() => CrkValidatorDirective),
      multi: true
    }
  ]
})
export class CrkValidatorDirective implements Validator {
  constructor(
    @Attribute(‘validateCrk‘) public validateCrk: string) {
  }
  validate(c: AbstractControl): { [key: string]: any } {
    // 控件自身值
    const self = c.value;
    // 控件的值是否等于‘crk‘
    if (self !== ‘crk‘) {
      return {
        validateCrk: true
      };
    }
    return null;
  }
}

响应式表单的自定义指令

  响应式的自定义校验相对来说较简单,需要满足ValidatorFn即可。

/**
    响应式表单自定义指令
    使用:
     {validator: [this.validateEqualCrk(‘nickName‘,‘gg‘)]}
*/
validateEqualCrk(confirmKey: string, confirmStr?:string): ValidatorFn {
  return (group: FormGroup): {[key: string]: any} => {
    const confirmField = group.controls[confirmKey];
    const pattenStr = confirmStr ? confirmStr : ‘crk‘
    if (confirmField.value !== pattenStr) {
      return {
        validateEqualCrk: true
      };
    }
      return null;
  };
}

父组件向子组件传递表单控制

  当表单中某个字段是以子组件的形式出现的时候,不能直接设置FormControl,因此需要向子组件传递FormControl然后在子组件添加,这样才可以实现父组件表单对子组件表单元素的控制。

代码素材

  你可以在以下git代码中找到我上述讲述的知识点的实例代码(angular的实例代码中的angular-form)代码中对如何创建模板驱动型表单,响应式表单、使用FormBuilder创建响应式表单、创建自定义指令(响应式表单的和模板驱动表单的自定义指令都有)以及深层次传递表单控制等知识点都有涉及到。

原文地址:https://www.cnblogs.com/shcrk/p/9216109.html

时间: 2024-11-08 23:13:40

angular表单的使用实例的相关文章

使用jquery实现的清空表单元素代码实例

使用jquery实现的清空表单元素代码实例:如果表单的元素较多的话,如果想情况以前填写的内容可能有点耗费体力,不够人性化,下面就介绍一下如何利用jquery代码实现快捷清除表单元素内容的功能,先看一段代码实例: $('#theform')[0].reset(); 很朋友可能认为上面的代码就完全实现我们的要求,其实这是错误的,reset()函数是重置的意思,也就是将表单元素的值重置为默认值而不是清空,如下面的文本框: <input type="text" value="蚂

【干货】Laravel --Validate (表单验证) 使用实例

前言 : Laravel 提供了多种方法来验证应用输入数据.默认情况下,Laravel 的控制器基类使用ValidatesRequests trait,该trait提供了便利的方法通过各种功能强大的验证规则来验证输入的 HTTP 请求.要掌握 Laravel 强大的验证特性,让我们先看一个完整的验证表单并返回错误信息给用户的例子. 在这之前如果您是首次接触 Laravel 而且并不知道路由如何跳转到指定的控制器 可以查看博主的Restfulapi或者Laravel官网对路由的介绍,在这里就不做介

当文本框失去焦点即进行表单验证简单实例

当文本框失去焦点即进行表单验证简单实例:不少的表单验证都有这样的功能,就是当鼠标焦点离开文本框的时候,即刻进行合法性验证,下面就通过一个实例简单介绍一下如何实现此功能,代码实例如下: <script type="text/javascript"> function onblurs(){ if(myform.name.value==""){ alert("姓名不得为空!"); } else if(myform.address.value

JQuery中一个简单的表单验证的实例

html代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv=&quo

jquery实现表单验证简单实例演示

/* 描述:基于jquery的表单验证插件. */ (function ($) { $.fn.checkForm = function (options) { var root = this; //将当前应用对象存入root var isok = false; //控制表单提交的开关 var pwd1; //密码存储 var defaults = { //图片路径 img_error: "img/error.gif", img_success: "img/success.gi

angular表单验证实例----可用的代码

前段时间,公司做一个单页面,就是一个表单验证,早开始在菜鸟教程上关注了angular,所以下派上用场了 angular里面对于表单验证,设置了很多指令. 也就是说不用自己写一些逻辑,直接绑定指令就行. ng-app     启动你angular的模块 ng-controller 控制器,启动你angualr里面的逻辑代码作用在页面上 ng-options  循环你select里面的option标签,很好用的 ng-submit,表单提交执行的 novalidate  表单form配合后期检测的

Angular表单验证

在使用 AngularJS 进行开发的时候,表单填写是一个很常见的需求,而表单验证又是比较让人头疼的部分,本文对此做一个总结. 在 Angular 的视图中使用的 form 已经不是 HTML 中的普通 form 了,而是一个被 Angular 封装过的指令.它可以完成普通 form 无法实现的功能,比如 form 嵌套,而且自带强大的验证功能. Angular 在对表单进行校验的时候会使用 ngModelController 上的属性,如果不设置 ng-model,则 Angular 无法知道

从浅入深剖析angular表单验证

最近手上维护的组件剩下的BUG都是表单验证,而且公司的表单验证那块代码经历的几代人,里面的逻辑开始变得不清晰,而且代码结构不是很angular. 是很有必要深入了解表单验证. <body ng-controller="MainController"> <form name="form" novalidate="novalidate"> <input name="text" type="e

简话Angular 05 Angular表单验证

一句话: 可以使用所有html5表单验证功能,同时Angular还增强了部分验证,支持动态验证 1. 上源码 1 <div ng-controller="ExampleController"> 2 <form action="" name="exampleForm"> 3 <label>姓名(required ng-minlength=1 ng-maxlength=3): </label> <