【Angular】ディレクティブでバリデータを設定する方法!


こんな悩みを解決できる記事を書きました!
僕は現役フリーランスエンジニア(歴10年)で、資格は13個保有しています。
「Angularのディレクティブでバリデータを設定する方法を知りたい」とお考えではありませんか?
Angularのディレクティブは様々な使い方ができますが、ディレクティブでバリデータを設定することも可能です。



複雑なバリデータや特定の項目のみにバリデータを付与したい場合に使えます。
まあ、わざわざディレクティブを使う必要もないですが、知っておくと便利です。


本記事を読めば、Angularのディレクティブでバリデータを設定する方法について分かるので早速見ていきましょう!



すぐ読み終わるので、ぜひ最後まで読んでくださいませ。
【Angular】ディレクティブでバリデータを設定する方法
早速ですが、Angularのディレクティブでバリデータを設定する方法を解説します。



今回は、特定の文字列「test」を禁止するバリデーションをディレクティブにしてみます。
バリデータのディレクティブ作成
import { Directive } from '@angular/core';
import { AbstractControl, NG_VALIDATORS, ValidationErrors, Validator } from '@angular/forms';
@Directive({
selector: '[appForbiddenWord]',
providers: [
{
provide: NG_VALIDATORS,
useExisting: ForbiddenWordDirective,
multi: true,
}
]
})
export class ForbiddenWordDirective implements Validator {
validate(control: AbstractControl): ValidationErrors | null {
const forbidden = /test/i.test(control.value);
return forbidden ? { forbiddenWord: { value: control.value } } : null;
}
}
入力値に「test」という単語が含まれていた場合に、バリデーションエラーを返すディレクティブを作成します。
テンプレート設定
<form [formGroup]="form">
<label>
入力欄:
<input formControlName="name" appForbiddenWord />
</label>
<div *ngIf="form.controls['name'].errors?.forbiddenWord">
「test」という単語は使用できません。
</div>
</form>
フォーム定義
import { Component } from '@angular/core';
import { FormBuilder, FormGroup } from '@angular/forms';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
})
export class AppComponent {
form: FormGroup;
constructor(private fb: FormBuilder) {
this.form = this.fb.group({
name: ['']
});
}
}



これでおしまい。
ディレクティブは結構便利なので個人的に重宝してます(笑)
よくある質問
ディレクティブでバリデータを作ると処理が重くなりませんか?
処理の軽さは基本的に変わりません。
Angularの仕組みに沿って動くため、公式のバリデータと同じように効率よく動作します。
複数の独自バリデータを1つの項目に適用できますか?
Angularは複数のバリデータを同時に適用できます。
ディレクティブ側でmulti: true
を設定すれば、他のバリデータと干渉せずに機能します。
まとめ
今回は、Angularのディレクティブでバリデータを設定する方法について解説しました。
以下が本記事のまとめになります。
- おすすめ本
Angularの勉強なら「Angularアプリケーションプログラミング



最後までお読みいただき、ありがとうございました!
- クソおすすめ本



海外のエンジニアがどういった思考で働いているかが理解できます。
海外に行く気はないけど海外エンジニアの動向が気になる雑魚エンジニアにおすすめです(本当におすすめな本しか紹介しないのでご安心を)。
- 他サイトも見てね