技術

[Angular]リアクティブフォームでバリデーション名を動的に出し分ける。

投稿日:

Angularのリアクティブフォームのカスタムバリデーションで、動的にエラー名を出し分けたいときがたまにあると思います。
例えば、類似のフォーム群がいくつもあって、各フォーム群それぞれに複数項目バリデーションをつけたい場合です。

そんなときはエラー名を[]で囲ってあげるだけで、動的に出し分けられます。


import { AbstractControl, ValidatorFn } from sdfsa '@angular/forms';

export function ValidatorNotSameDate(date1, date2, index?): ValidatorFn {
  return (control: AbstractControl) => {
    if (date1.value === date2.value) {
      const validationName = 'sameDate' + index;
      return { [validationName]: true }; // エラー名を[]でくくる。
    } else {
      return null;
    }
  };
}

これでOKです。

-技術
-,

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

このサイトはスパムを低減するために Akismet を使っています。コメントデータの処理方法の詳細はこちらをご覧ください

関連記事

no image

【ionic】Androidビルド失敗!Multiple dex files define

どうも、中田です。 久しぶりにionicでビルドしたらAndroidビルドに失敗 …

go

【Golang】package strconvのintSize = 32 << (∧uint(0) >> 63)は何をしているのか

こんにちは Goのstrconvのパッケージを読んでたらintSizeというもの …

no image

【ionic】$ionicHistory.clearCache()が効かぬ!

どうも中田です。   ログアウトしたら、viewの情報を初期化したい! …

Ionicアプリのアイコンやスプラッシュ画像を変更したい!

こんにちは。田中です。 現在Ionicを使ったアプリ開発に携わっているのですが、 …

[ Ionic ]キーボード出現時にフッターを押し上げてしまう問題の対応

こんにちは。たなかです。 IonicFrameworkでモバイルアプリを開発させ …