I want to permit user to enter alphanumeric and whitespace only in this input field, but I can't seem to get it to work.
I can enter alphanumeric, but unable to enter whitespace.
I tried using /[^0-9a-zA-Z\.\\s]/g ,
/[^0-9a-zA-Z \.]/g,
/[^\w ]/g but none of them worked. Please help.
app.directive('onlyAlphabets', function() {
return {
require: '?ngModel',
link: function(scope, element, attrs, ngModelCtrl) {
if(!ngModelCtrl) {
return;
}
ngModelCtrl.$parsers.push(function(val) {
if (angular.isUndefined(val)) {
var val = '';
}
var clean = val.replace(/[^0-9a-zA-Z\.]/g, '');
var decimalCheck = clean.split('.');
if(!angular.isUndefined(decimalCheck[1])) {
decimalCheck[1] = decimalCheck[1].slice(0,2);
clean =decimalCheck[0] + '.' + decimalCheck[1];
}
if (val !== clean) {
ngModelCtrl.$setViewValue(clean);
ngModelCtrl.$render();
}
return clean;
});
element.bind('keypress', function(event) {
if(event.keyCode === 32) {
event.preventDefault();
}
});
}
};
})