欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

angular4中關(guān)于表單的校驗(yàn)示例

 更新時(shí)間:2017年10月16日 09:05:31   作者:水痕01  
本篇文章主要介紹了angular4中關(guān)于表單的校驗(yàn)示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

本章中介紹響應(yīng)式表單的創(chuàng)建及表單輸入值的校驗(yàn),對(duì)于模板表單就略過(guò)。

一、使用響應(yīng)式表單的步驟

1、在模塊(一般是app.module.ts)中引入ReactiveFormsModule
2、在組件的ts文件中使用響應(yīng)式表單

import { FormGroup, FormBuilder, Validators, FormControl } from '@angular/forms';
export class ReactiveFormComponent implements OnInit {
  private myForm: FormGroup;
  constructor(private fb: FormBuilder) {
    this.createForm();
  }

  ngOnInit() {
  }
  // 創(chuàng)建表單元素
  createForm() {
    this.myForm = this.fb.group({
      username: ['', [Validators.required, Validators.minLength(3), Validators.maxLength(6)]],
      mobile: ['', [Validators.required]],
      password: this.fb.group({
        pass1: [''],
        pass2: ['']
      })
    });
  }
  // 提交表單函數(shù)
  postDate() {
    /**
     * valid:是否有效
     * invalid:無(wú)效
     * dirty:臟
     * status:狀態(tài)
     * errors:顯示錯(cuò)誤
     */
    if(this.myForm.valid){
      console.log(this.myForm.value);
    }
  }
}

3、在組件的html頁(yè)面中使用

<form [formGroup]="myForm" (ngSubmit)="postDate()">
  <div class="form-group">
    <label for="username">用戶名:</label>
    <input type="text" placeholder="請(qǐng)輸入用戶名" class="form-control" id="username" formControlName="username" />
  </div>
  <div class="form-group">
    <label for="mobile">手機(jī)號(hào)碼:</label>
    <input type="text" placeholder="請(qǐng)輸入手機(jī)號(hào)碼" 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="請(qǐng)輸入密碼" formControlName="pass1" />
    </div>
    <div class="form-group">
      <label>確認(rèn)密碼:</label>
      <input type="password" class="form-control" placeholder="請(qǐng)?jiān)俅屋斎朊艽a" formControlName="pass2" />
    </div>
  </div>
  <div class="form-group">
    <input type="submit" value="提交" class="btn btn-warning" [disabled]="!myForm.valid" />
  </div>
</form>

二、使用表單校驗(yàn)數(shù)據(jù)

1、angular中自帶了三個(gè)常見(jiàn)的表單校驗(yàn)的是在Validators中的required,minLength,maxLength
2、自定義表單校驗(yàn)器(其實(shí)就一個(gè)函數(shù),函數(shù)的參數(shù)是當(dāng)前需要校驗(yàn)的行,返回一個(gè)任意對(duì)象)

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

}

3、響應(yīng)式表單字段中可以寫三個(gè)值,第一個(gè)是返顯到頁(yè)面上的,第二個(gè)參數(shù)是校驗(yàn)器(可以是一組),第三個(gè)參數(shù)異步校驗(yàn)(常見(jiàn)判斷手機(jī)號(hào)碼,用戶名是否重復(fù)注冊(cè))

三、自定義一個(gè)校驗(yàn)方法的步驟

1、把項(xiàng)目中需要用的校驗(yàn)器單獨(dú)寫一個(gè)文件

import { FormControl, FormGroup } from '@angular/forms';
/**
 * 自定義驗(yàn)證器(其實(shí)就是一個(gè)函數(shù),一個(gè)返回任意對(duì)象的函數(shù))
 * 傳遞的參數(shù)是當(dāng)前需要驗(yàn)證的表單的FormControl
 * 通過(guò)傳遞的參數(shù)獲取當(dāng)前表單輸入的值
 */
export function mobileValidator(control: FormControl): any {
  console.dir(control);
  // 獲取到輸入框的值
  const val = control.value;
  // 手機(jī)號(hào)碼正則
  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: '手機(jī)號(hào)碼格式不正確' } };
}

2、使用自己定義的校驗(yàn)器

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、定義一個(gè)密碼組的校驗(yàn)

// 定義一個(gè)密碼組的驗(yàn)證方法
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})
  });
}

四、關(guān)于前端頁(yè)面中錯(cuò)誤的顯示

1、頁(yè)面顯示錯(cuò)誤

<div class="form-group">
  <label for="username">用戶名:</label>
  <input type="text" placeholder="請(qǐng)輸入用戶名" class="form-control" id="username" formControlName="username" />
  <!-- 當(dāng)輸入框沒(méi)有訪問(wèn)的時(shí)候或者合法的時(shí)候不顯示 -->
  <div [hidden]="myForm.get('username').valid || myForm.get('username').untouched">
    <p [hidden]="!myForm.hasError('required','username')">用戶名必填的</p>
    <p [hidden]="!myForm.hasError('minlength','username')">用戶名長(zhǎng)度過(guò)短</p>
    <p [hidden]="!myForm.hasError('maxlength','username')">用戶名長(zhǎng)度太長(zhǎng)</p>
  </div>
</div>
<div class="form-group">
  <label for="mobile">手機(jī)號(hào)碼:</label>
  <input type="text" placeholder="請(qǐng)輸入手機(jī)號(hào)碼" 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')?.info}}</p>
  </div>
</div>
<div formGroupName="password" style="border:none;">
  <div class="form-group">
    <label>密碼:</label>
    <input type="password" class="form-control" placeholder="請(qǐng)輸入密碼" formControlName="pass1" />
  </div>
  <div class="form-group">
    <label>確認(rèn)密碼:</label>
    <input type="password" class="form-control" placeholder="請(qǐng)?jiān)俅屋斎朊艽a" formControlName="pass2" />
  </div>
  <!-- 對(duì)于group可以不在外面加一層判斷 -->
  <div>
    <p [hidden]="!myForm.hasError('passValidator','password')">
      {{myForm.getError('passValidator','password')?.info}}
    </p>
  </div>
</div>

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;
}

五、自定義class顯示錯(cuò)誤

1、在input輸入框上寫上

表示該字段無(wú)效且觸碰過(guò)就添加這個(gè)class=”error”

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 深入理解Angular.JS中的Scope繼承

    深入理解Angular.JS中的Scope繼承

    這篇文章主要給大家深入的介紹了關(guān)于Angular.JS中Scope繼承的相關(guān)資料,Angular。JS中scope之間的繼承關(guān)系使用JavaScript的原型繼承方式實(shí)現(xiàn),文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-06-06
  • Angular 4 依賴注入學(xué)習(xí)教程之FactoryProvider的使用(四)

    Angular 4 依賴注入學(xué)習(xí)教程之FactoryProvider的使用(四)

    這篇文章主要給大家介紹了關(guān)于Angular 4 依賴注入之FactoryProvider使用的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Angular4具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-06-06
  • AngularJS輕松實(shí)現(xiàn)雙擊排序的功能

    AngularJS輕松實(shí)現(xiàn)雙擊排序的功能

    網(wǎng)上已經(jīng)有AngularJS比較多的相關(guān)教程了,那么這篇文章我們一起來(lái)看一個(gè)AngularJS雙擊排序的例子,對(duì)大家日常開發(fā)很有幫助的,有需要的可以參考借鑒。
    2016-08-08
  • AngularJS使用ng-app自動(dòng)加載bootstrap框架問(wèn)題分析

    AngularJS使用ng-app自動(dòng)加載bootstrap框架問(wèn)題分析

    這篇文章主要介紹了AngularJS使用ng-app自動(dòng)加載bootstrap框架問(wèn)題,分析了前面文章中所述的ng-app自動(dòng)加載bootstrap出現(xiàn)的錯(cuò)誤原因與相應(yīng)的解決方法,需要的朋友可以參考下
    2017-01-01
  • 詳解Angular路由之子路由

    詳解Angular路由之子路由

    本文將介紹Angular子路由的用法,對(duì)此感興趣的同學(xué),可以參考下
    2021-05-05
  • 詳解在Angular項(xiàng)目中添加插件ng-bootstrap

    詳解在Angular項(xiàng)目中添加插件ng-bootstrap

    這篇文章主要介紹了詳解在 Angular 項(xiàng)目中添加插件 ng-bootstrap,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • AngularJS打開頁(yè)面隱藏顯示表達(dá)式用法示例

    AngularJS打開頁(yè)面隱藏顯示表達(dá)式用法示例

    這篇文章主要介紹了AngularJS打開頁(yè)面隱藏顯示表達(dá)式用法,結(jié)合實(shí)例形式分析了AngularJS中打開頁(yè)面隱藏顯示表達(dá)式相關(guān)命令使用技巧,需要的朋友可以參考下
    2016-12-12
  • Angular.JS中select下拉框設(shè)置value的方法

    Angular.JS中select下拉框設(shè)置value的方法

    select 是 AngularJS 預(yù)設(shè)的一組directive。下面這篇文章主要給大家介紹了關(guān)于Angular.JS中select下拉框設(shè)置value的方法,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-06-06
  • Angular中ng-options下拉數(shù)據(jù)默認(rèn)值的設(shè)定方法

    Angular中ng-options下拉數(shù)據(jù)默認(rèn)值的設(shè)定方法

    本篇文章主要介紹了Angular中ng-options下拉數(shù)據(jù)默認(rèn)值的設(shè)定方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • 分享使用AngularJS創(chuàng)建應(yīng)用的5個(gè)框架

    分享使用AngularJS創(chuàng)建應(yīng)用的5個(gè)框架

    如果你計(jì)劃使用AngularJS創(chuàng)建你的Web應(yīng)用,那現(xiàn)在就開始吧。你不需要有任何的恐懼和擔(dān)心,因?yàn)楝F(xiàn)在有很多的框架都可以很好地支持AngularJS
    2015-12-12

最新評(píng)論