Yesterday, we looked at how to write a validation function that works with reactive forms. Template-driven forms have a somewhat similar approach that also uses a validator function but requires a wrapper directive that implements the Validator
interface like this one (example here):
data:image/s3,"s3://crabby-images/7b4dc/7b4dcec85052dc05783077d028c06c52a10415f3" alt=""
The easiest solution to write a validation function that works with both reactive forms and template-driven forms is to create a directive for the template-driven form validation and then expose the validation function as a static method of that class:
data:image/s3,"s3://crabby-images/62a51/62a512eeb0a37017e396f2b0d4e848a98bcdbb7f" alt=""
A static method has two advantages in that scenario:
- It’s public
- It does not require an instance of the class (we can refer to it as
CreditCardValidator.validateCcNumber
)
As a result, we’d use our validation feature like this in a template-driven form:
data:image/s3,"s3://crabby-images/28f55/28f55d4562d78b865a45345dfc2cb4aeffd1b339" alt=""
And like that in a reactive form:
data:image/s3,"s3://crabby-images/e63df/e63df7a8d874de6a19826ff21e8a64dd0de8b235" alt=""
data:image/s3,"s3://crabby-images/d90d5/d90d52b7c7259c7a58dc6f356a4335d9b73e0cd6" alt=""
You can check the complete code for that example on Stackblitz here. Here is another tutorial for more information on that validation approach.