2

从我在网上看到的所有内容来看,以下代码似乎应该执行以下操作(这是我的期望):

  • 如果电子邮件(“帮助”)与正则表达式不匹配,则显示警报消息并返回 false
  • 如果密码(“pass”)为空,则显示警报消息并返回 false
  • 如果两个条件都通过验证,则提交表单

Javascript如下:

function validate() {
var email = document.getElementById('aid').value;
var pass = document.getElementById('apw').value;        
var emailPattern = /^[a-zA-Z0-9._-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,4}$/;  
if (!emailPattern.test(email)) {
    alert("Not a valid email address");
    return false;
}
if (pass == null || pass == "") {
    alert("Password is blank");
    return false;   
}
return true;
}

标签的开头如下:

<form action="choose.php" onsubmit="validate();" method="post">

我遇到的问题是,当单击提交按钮时,会弹出警报消息,但随后在浏览器中加载了 choose.php。如果触发了错误条件,我希望脚本保留在页面上,直到两个条件都通过。

4

1 回答 1

4

您需要将 onSubmit 更改为onSubmit="return validate();". 这样,当它返回 false 时,表单不会被提交。现在它只是调用 validate() 函数并继续提交表单

于 2012-11-28T00:03:49.777 回答