HTML forms are evolving but still lacking a little in masking, which really means “suggesting the proper format to the user.
For instance, if I need to capture a US phone number in a specific format, I’d like to use a mask that looks like this:
data:image/s3,"s3://crabby-images/cf6c2/cf6c26ff3fa8bce7fcece3f51e1af3337348848a" alt=""
We could use a placeholder, but the placeholder disappears as soon as we start typing, whereas a mask should remain visible and try to make the user input fit into that format. For instance:
data:image/s3,"s3://crabby-images/bd43b/bd43b6752dc764080c7c5fc9d217a3abec48288a" alt=""
This is where ngx-mask helps. It’s a third-party library that passes my acceptance criteria for dependencies. ngx-mask comes with directives and pipes to implement customizable masks.
To install it: npm install ngx-mask
You can find out how to configure the library here. Here is an example of the mask directive used for a US phone number:
data:image/s3,"s3://crabby-images/fea53/fea53d7f6b5478d3aa44e6d428076ade5102f35a" alt=""
And another one for a French phone number that doesn’t show the mask as we type but still enforces it:
data:image/s3,"s3://crabby-images/40964/40964837663fac8b05fc679680fd0ce8f780daf1" alt=""
The result looks like this:
data:image/s3,"s3://crabby-images/a7c79/a7c7905e8f92a61f354d2cd2ce4f42291f3f0d32" alt=""
Here is a link to my example on Stackblitz.
You can try many different demos on this website. The library supports regular expressions and lots of other options, such as a validation
attribute to invalidate the form when the input is invalid:
data:image/s3,"s3://crabby-images/317b9/317b9b68cc81d8cb56c32277cb896284aa542e8f" alt=""
And it’s possible to have multiple different acceptable formats on a mask, too:
data:image/s3,"s3://crabby-images/c59b6/c59b6a2c20af108ef141f6c0c5baa38b46e4abd4" alt=""