首页 >

angular4关于表单校验步奏详解

web前端|js教程angular4关于表单校验步奏详解
angular4,详解,校验
web前端-js教程本章中介绍响应式表单的创建及表单输入值的校验,对于模板表单就略过。
自动发卡网企业源码,vnc不能连接ubuntu,小众爬虫用品品牌,php origin,桓台seo推广lzw
A、使用响应式表单的步骤
鑫众源码下载,vscode代码拉去取提交,ubuntu 登录蓝屏,tomcat使用内存溢出,别墅进爬虫,php 改变二维数组的值,石碣seo优化关键词费用,发布c 网站源码lzw
1、在模块(一般是app.module.ts)中引入ReactiveFormsModule
2、在组件的ts文件中使用响应式表单
易语言盗号源码收不到邮件,vscode生成随机数,ubuntu sudo等待,tomcat如何运行网页,爬虫蜘蛛幼体,php 防止刷票,沙井seo优化哪里好,建站系统网站php源码,会计工商报账模板lzw
import { FormGroup, FormBuilder, Validators, FormControl } from '@angular/forms';export class ReactiveFormComponent implements OnInit {  private myForm: FormGroup;  constructor(private fb: FormBuilder) {    this.createForm();  }  ngOnInit() {  }  // 创建表单元素  createForm() {    this.myForm = this.fb.group({      username: ['', [Validators.required, Validators.minLength(3), Validators.maxLength(6)]],      mobile: ['', [Validators.required]],      password: this.fb.group({        pass1: [''],        pass2: ['']      })    });  }  // 提交表单函数  postDate() {    /**     * valid:是否有效     * invalid:无效     * dirty:脏     * status:状态     * errors:显示错误     */    if(this.myForm.valid){      console.log(this.myForm.value);    }  }}

3、在组件的html页面中使用

  

B、使用表单校验数据

1、angular中自带了三个常见的表单校验的是在Validators中的required,minLength,maxLength
2、自定义表单校验器(其实就一个函数,函数的参数是当前需要校验的行,返回一个任意对象)

**格式**export function fnName(control:FormControl|FormGroup):any{}

3、响应式表单字段中可以写三个值,第一个是返显到页面上的,第二个参数是校验器(可以是一组),第三个参数异步校验(常见判断手机号码,用户名是否重复注册)

C、自定义一个校验方法的步骤

1、把项目中需要用的校验器单独写一个文件

import { FormControl, FormGroup } from '@angular/forms';/** * 自定义验证器(其实就是一个函数,一个返回任意对象的函数) * 传递的参数是当前需要验证的表单的FormControl * 通过传递的参数获取当前表单输入的值 */export function mobileValidator(control: FormControl): any {  console.dir(control);  // 获取到输入框的值  const val = control.value;  // 手机号码正则  const mobieReg = /^(((13[0-9]{1})|(15[0-9]{1})|(18[0-9]{1}))+\d{8})$/;  const result = mobieReg.test(val);  return result ? null : { mobile: { info: '手机号码格式不正确' } };}

2、使用自己定义的校验器

createForm() {  this.myForm = this.fb.group({    username: ['', [Validators.required, Validators.minLength(3), Validators.maxLength(6)]],    mobile: ['', [Validators.required, mobileValidator]],    password: this.fb.group({      pass1: [''],      pass2: ['']    })  });}

3、定义一个密码组的校验

// 定义一个密码组的验证方法export function passValidator(controlGroup: FormGroup): any {  // 获取密码输入框的值  const pass1 = controlGroup.get('pass1').value as FormControl;  const pass2 = controlGroup.get('pass2').value as FormControl;  console.log('你输入的值:', pass1, pass2);  const isEqule: boolean = (pass1 === pass2);  return isEqule ? null : { passValidator: { info: '两次密码不一致' } };}

4、使用

createForm() {  this.myForm = this.fb.group({    username: ['', [Validators.required, Validators.minLength(3), Validators.maxLength(6)]],    mobile: ['', [Validators.required, mobileValidator]],    password: this.fb.group({      pass1: [''],      pass2: ['']    }, {validator: passValidator})  });}

D、关于前端页面中错误的显示

1、页面显示错误

用户名必填的

用户名长度过短

用户名长度太长

{{myForm.getError('mobile', 'mobile')?.info}}

{{myForm.getError('passValidator','password')?.info}}

2、定义样式文件

.ng-touched:not(form),.ng-invalid:not(form) {  border: 1px solid #f00;}.ng-valid:not(form),.ng-untouched:not(form) {  border: 1px solid #ddd;}p{  color:#f00;}

E、自定义class显示错误

1、在input输入框上写上

表示该字段无效且触碰过就添加这个class=”error”

 [class.error]="myForm.get('username').invalid && myForm.get('username').touched"


angular4关于表单校验步奏详解
  • Angular4表单响应功能示例分析
  • Angular4表单响应功能示例分析 | Angular4表单响应功能示例分析 ...

    angular4关于表单校验步奏详解
  • Angular4中router使用技巧
  • Angular4中router使用技巧 | Angular4中router使用技巧 ...

    angular4关于表单校验步奏详解
  • .Net Core + Angular Cli 实现开发环境搭建
  • .Net Core + Angular Cli 实现开发环境搭建 | .Net Core + Angular Cli 实现开发环境搭建 ...