今回はReactive Formのカスタムvalidatorについてご紹介します。 Reactive Formのカスタムバリデーターを使用する際の注意事項を実際に見てみましょう。
この記事では、Angular (Angular2+) のリアクティブ フォームの関連コンテンツを紹介します:registerForm: FormGroup; constructor( private fb: FormBuilder, ) {} ngOnInit() { this.registerForm = this.fb.group({ firstName: [''], lastName: [''], }) }
firstName
と lastName
は自分で取得したもので、それぞれフォームコントロール名。 その後、HTML ページは次のようになります: firstName
和lastName
是由你自己取的,分别表示一个表单控件名称。
然后HTML页面就像这样:
<form [formGroup]="registerForm" (ngSubmit)="handleSubmit(registerForm)"> <label>FirstName:</label> <input formControlName="firstName"> <label>LastName:</label> <input formControlName="lastName"> <button type="submit">Submit</button> </form>
这样就创建了一个非常简单的表单!
表单的输入项经常是要进行验证的,那该怎么验证呢?
其实很简单,Angular已经为我们写好了一些常用的验证器,就像这样使用就可以了:
ngOnInit() { this.registerForm = this.fb.group({ firstName: ['', Validators.required], lastName: ['', Validators.pattern('[A-Za-z0-9]*')], }) }
可以使用“必要”验证器,也可以使用正则,你只需传入一个正则表达式就可以了。除此之外,还有minLength
和maxLength
等。
如果一个控件需要多个验证器,可以把它们放在一个数组里面:
lastName: ['', [Validators.pattern('[A-Za-z0-9]*'), Validators.required]]
如果你希望在输入时得到一些提示,可以这样写你的HTML:
<form [formGroup]="registerForm" (ngSubmit)="handleSubmit(registerForm)"> <label>FirstName:</label> <input formControlName="firstName"> <p *ngIf="registerForm.controls.firstName.touched && registerForm.controls.firstName.invalid"> This field is required! </p> <label>LastName:</label> <input formControlName="lastName"> <p *ngIf="registerForm.controls.lastName.hasError('pattern')"> Invalid input! </p> <button type="submit" [disabled]="!registerForm.valid">Submit</button> </form>
第一个控件,在你“touch”过又为空的情况下会给出提示;第二个控件,在输入不符合正则表达式规则的情况下给出提示,hasError
方法还可以传入required
、minLength
等参数,分别对应不同的验证器;最后,在输入还未符合规则的时候,Submit按钮是处于禁用状态的。
Angular提供的几个验证器在实际项目中往往是不够用的,因此我们需要自定义验证器,以满足我们的业务需求!
验证器其实就是一个有着return
export function validateUrl(control: AbstractControl){ if(control.value){ if(!control.value.startsWith('www') || !control.value.includes('.io')){ return { inValidUrl: true } } } return null; }
認証の使い方
フォームの入力項目は認証が必要なことが多いのですが、どうやって認証するのでしょうか?
これは実際には非常に簡単です。Angular には、一般的に使用されるバリデーターがすでに用意されています。次のように使用します。this.registerForm = this.fb.group({ firstName: ['', Validators.required], lastName: ['', [Validators.pattern('[A-Za-z0-9]*'), Validators.required]], website: ['', validateUrl], // <--- })
が役に立ちます。さらに、minLength
や maxLength
などがあります。
<label>Website:</label> <input formControlName="website"> <p *ngIf="registerForm.controls.website.invalid"> Url must starts with www and includes .io </p>
rrreee「タッチ」した後、最初のコントロールは空です。入力が正規表現ルールに準拠していない場合、2 番目のコントロールはプロンプトを表示します。hasError
メソッドは、required や などの <code> パラメータを渡すこともできます。 >minLength
はそれぞれ異なるバリデータに対応し、最終的に、入力がルールに準拠していない場合、[送信] ボタンが無効になります。
Angular が提供するいくつかのバリデーターは実際のプロジェクトでは十分ではないことが多いため、ビジネス ニーズを満たすようにバリデーターをカスタマイズする必要があります。
カスタムバリデーター バリデーターは実際には return
を持つメソッドです。
次に、URL 入力ボックスの値がルールに準拠しているかどうかを検証するバリデータを作成しましょう:
以上がリアクティブフォームのカスタムバリデーターの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。