I have a JavaScript function that validates an input field and prevents the user from typing anything that doesn’t match the condition. This function is based on event.keyCode.
I’m trying to modify the function to use a RegExp and validates not “per character” but “per whole input” so that it does the same, but with different conditions:
- numeric only
- allowed decimal “.” or “,”
Here is the function in its current form, using event.keyCode:
function isNumeric(evt, alertDIVid, alertMsg) {
var charCode = (evt.which) ? evt.which : event.keyCode
if (charCode >= 48 && charCode <= 57) {
document.getElementById(alertDIVid).innerHTML = '';
return true;
}
else {
document.getElementById(alertDIVid).innerHTML = alertMsg;
return false;
}
}
document.getElementById('AMNT').onkeypress = function(event) {
event = event || window.event;
return isNumeric(event, 'numericalert', 'Numeric values only!')
};
In order to do the kind of validation you want, you need to listen to the
keyupevent instead. This event fires after the field is changed, so that you know the new value of the field. You also need to know the previous value of the field so you can “reset” it if what the user typed turns out to be invalid.For example:
Working demo: http://jsfiddle.net/8kUdG/
It’s worth noting that this will also validate empty strings, as well as unfinished numbers, like
5,or42.(otherwise the user would have to insert the decimal sign after typing the decimals, which would be… weird).And finally, keep in mind that this might not be a cross-browser safe solution. If you need a pure-JavaScript solution, you will need to refine it (i.e., this might not work in IE).
Edit: of course, showing an error message instead of resetting the input field to the previous value is also perfectly possible (updated JSFiddle):
I leave it up to you to replace thealertwith something more user-friendly.