I'm trying to write a directive that automatically formats a number in the <input>
but the the model isn't formatted.
Getting it to work is fine, on load the value in the input is displayed as 1,000,000 and 1000000 in the controller, however when typing only the ngModel.$parsers
function fires.
The only time when the ngModel.$formatters
fire is when the directive gets loaded and when the value is 0.
How can I make it work on keypress(I've tried binding to keypress/keyup but it doesn't work).
Here's my code:
angular.module('myApp.directives', []).directive('filterInput', ['$filter', function($filter) {
return {
restrict: 'A',
require: 'ngModel',
link: function(scope, element, attr, ngModel) {
ngModel.$parsers.push(function fromUser(text) {
return parseInt(text.replace(",", ""));
});
ngModel.$formatters.push(function toUser(text) {
console.log($filter('number')(text));
return ($filter('number')(text || ''));
});
}
};
}]);
See Question&Answers more detail:os