So I’m using the minimal regex [0-9]* for the iPhone number pad in my HTML5 pattern attributes. I also had a submit function that sends an email through the server. Everything was working good until I realized it was trying to send the form re3gardless of whether the browser was trying to block submit based on incorrect user input.
So I did the following but can’t get it to work:
<script>
function validate(){
var phone=/[0-9]*/;
var x=document.forms["form"]["contactnum"].value;
if (x!=phone){
alert("Contact Number must be a valid phone number (no dashes)");
return false;
}
else {
alert("Thank you! We have received your information and will contact you shortly.");
ajax('{{=URL('new_post')}}',['phone'], 'target');
return false;
}
}
</script>
The problem is I can only get it to work if I set if (x==null || x==””) in the if statement. If I try to match it with any other var it will always say I’m not matching the [0-9]*. I already have written several complex regex’s but really don’t want to use anything on this simple form. I just wanted the number pad on the iPhone and not to submit if it wasn’t a digit or null. I don’t even care if they put in a “2” for the phone, just so long as it’s a digit.
Thanks.
That’s not how you use a regular expression:
Also if you want to match a string with nothing but digits, try
That will match the empty string too; use
+instead of*if you want at least one digit.