本章中介绍响应式表单的创建及表单输入值的校验,对于模板表单就略过。
一、使用响应式表单的步骤
1、在模块(一般是app.module.ts)中引入ReactiveFormsModule
2、在组件的ts文件中使用响应式表单
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页面中使用
<form [formGroup]="myForm" (ngSubmit)="postDate()"> <div class="form-group"> <label for="username">用户名:</label> <input type="text" placeholder="请输入用户名" class="form-control" id="username" formControlName="username" /> </div> <div class="form-group"> <label for="mobile">手机号码:</label> <input type="text" placeholder="请输入手机号码" class="form-control" id="mobile" formControlName="mobile"/> </div> <div formGroupName="password" style="border:none;"> <div class="form-group"> <label>密码:</label> <input type="password" class="form-control" placeholder="请输入密码" formControlName="pass1" /> </div> <div class="form-group"> <label>确认密码:</label> <input type="password" class="form-control" placeholder="请再次输入密码" formControlName="pass2" /> </div> </div> <div class="form-group"> <input type="submit" value="提交" class="btn btn-warning" [disabled]="!myForm.valid" /> </div> </form>
二、使用表单校验数据
1、angular中自带了三个常见的表单校验的是在Validators中的required,minLength,maxLength
2、自定义表单校验器(其实就一个函数,函数的参数是当前需要校验的行,返回一个任意对象)
**格式** export function fnName(control:FormControl|FormGroup):any{ }
3、响应式表单字段中可以写三个值,第一个是返显到页面上的,第二个参数是校验器(可以是一组),第三个参数异步校验(常见判断手机号码,用户名是否重复注册)
三、自定义一个校验方法的步骤
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 "htmlcode">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 "htmlcode">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}) }); }四、关于前端页面中错误的显示
1、页面显示错误
<div class="form-group"> <label for="username">用户名:</label> <input type="text" placeholder="请输入用户名" class="form-control" id="username" formControlName="username" /> <!-- 当输入框没有访问的时候或者合法的时候不显示 --> <div [hidden]="myForm.get('username').valid || myForm.get('username').untouched"> <p [hidden]="!myForm.hasError('required','username')">用户名必填的</p> <p [hidden]="!myForm.hasError('minlength','username')">用户名长度过短</p> <p [hidden]="!myForm.hasError('maxlength','username')">用户名长度太长</p> </div> </div> <div class="form-group"> <label for="mobile">手机号码:</label> <input type="text" placeholder="请输入手机号码" class="form-control" id="mobile" formControlName="mobile"/> <div [hidden]="myForm.get('mobile').valid || myForm.get('mobile').untouched"> <p [hidden]="!myForm.hasError('mobile', 'mobile')">{{myForm.getError('mobile', 'mobile')"password" style="border:none;"> <div class="form-group"> <label>密码:</label> <input type="password" class="form-control" placeholder="请输入密码" formControlName="pass1" /> </div> <div class="form-group"> <label>确认密码:</label> <input type="password" class="form-control" placeholder="请再次输入密码" formControlName="pass2" /> </div> <!-- 对于group可以不在外面加一层判断 --> <div> <p [hidden]="!myForm.hasError('passValidator','password')"> {{myForm.getError('passValidator','password')"htmlcode">.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; }五、自定义class显示错误
1、在input输入框上写上
表示该字段无效且触碰过就添加这个class=”error”
[class.error]="myForm.get('username').invalid && myForm.get('username').touched"以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2024年11月19日
2024年11月19日
- 群星.2022-福茂巨星·时空之轮日本唱片志系列DISC2范晓萱-RAIN【福茂】【WAV+CUE】
- 王闻-《男人四十4》[正版CD低速原抓WAV+CUE]
- 青燕子-八只眼演唱组《爱心》[WAV+CUE]
- 祁露想着你的好》WAV+CUE
- 陈致逸《赴梦之约 游戏主题原声音乐》[FLAC/分轨][159.96MB]
- 贵族音乐《睡眠自然流水声 ASMR白噪音背景音》[320K/MP3][155.72MB]
- 贵族音乐《睡眠自然流水声 ASMR白噪音背景音》[FLAC/分轨][857.58MB]
- 朱昕嵘《琴意绵绵6N纯银SQCD》[WAV+CUE]
- 降央卓玛《草原情6N纯银SQCD》WAV+CUE
- 傲日格乐《黑马琴HQCD》[WAV+CUE]
- 群星.2022-福茂巨星·时空之轮日本唱片志系列DISC3范晓萱-自言自语【福茂】【WAV+CUE】
- 群星.2022-福茂巨星·时空之轮日本唱片志系列DISC4那英-白天不懂夜的黑【福茂】【WAV+CUE】
- 群星.2015-华丽上班族电影原声大碟【大右音乐】【WAV+CUE】
- 陈粒《乌有乡地图》[320K/MP3][21.81MB]
- 陈粒《乌有乡地图》[FLAC/分轨][398.39MB]