I can’t figure out what is missing so that when e-mail is valid it will skip the last invalid message and move to next item on form for validation:
enter code here
if (document.form1.email.value.length > 0) {
var tst = document.form1.email.value;
var okd = ['bankofamerica.com','baml.com','magner.com','ml.com','ust.com','ustrust.com']
for (var i = 0; i < okd.length; i++) { okd[i] == okd[i].toLowerCase() }
var emailRE = /^[a-zA-Z0-9._+-]+@([a-zA-Z0-9.-]+\.[a-zA-Z]{2,4})$/
var aLst = emailRE.exec(tst)
if (!aLst) {
alert(tst + ' is not a valid e-mail')
} else {
var sLst = aLst[1].toLowerCase()
for (var i = 0; i < okd.length; i++) {
if (sLst == okd[i]) {
// alert(aLst[1] + ' is allowed');-->
}
}
if (i == okd.length) alert(aLst[1] + ' is not allowed. Please enter an email address with an authorized domain.')
document.form1.email.select();
return false;
}
}
I’d recommend placing this code into a function, maybe named
ValidateEmail().In your loop: if you’ve determined the email is valid,
return true;. This will prevent further execution. If that domain doesn’t match, have it continue looping to check the others.If the loop completes without returning
true, you’ll know it didn’t match anything soreturn false;at the very end.EDIT: Use try/catch instead:
throwbasically acts like agotocommand. It will jump directly to thecatch(err)portion of the code.More info about try, catch, and throw: