Den Den - 5 months ago 17x
HTML Question

Why does Angular provide ng-maxlength when there is a standard maxlength?

HTML provides a standard maxlength attribute since version 4.01.
Angular provides a ng-maxlength directive.

The difference is that the standard approach doesn't allow entering more than max, while Angular's approach just generates a validation error.

Why did they decide to include such a directive? It's not because of dynamic data binding of maxlength since the behaviour is inconsistent. It's not because of compatibility since it's available even in HTML 4.01. My only guess is that it's there to provide an alternative validation paradigm, but it sounds like over-engineering.


Not only it provide validation for max length, it also adds a class ng-invalid-maxlength. so when you put anything beyond the limit ng-invalid-maxlength class will placed there and in that class you can write your own css.

So after key press if validation fails, the css will be invoked simultaneously and reflects on your UI.