我有一个现有表格的网站,它向第三方网站(foo.com)提交电子邮件地址。现在,我想在使用Javascript提交表单之前验证电子邮件输入字段。
我的Javascript
function isValidEmailAddress(emailAddress) {
var pattern = new RegExp(/^(("[\w-\s]+")|([\w-]+(?:\.[\w-]+)*)|("[\w-\s]+")([\w-]+(?:\.[\w-]+)*))(@((?:[\w-]+\.)*\w[\w-]{0,66})\.([a-z]{2,6}(?:\.[a-z]{2})?)$)|(@\[?((25[0-5]\.|2[0-4][0-9]\.|1[0-9]{2}\.|[0-9]{1,2}\.))((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})\.){2}(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})\]?$)/i);
return pattern.test(emailAddress);
}
function formCheck() {
// Fetch email-value
sEmail = document.myForm.recipientEmail.value ;
// value empty?
if (sEmail == 0)
{
alert('Enter Email-Address.');
return false;
}
else
{
// value valid?
if (!isValidEmailAddress(sEmail))
{
alert('Enter valid Email-Address.');
return false;
}
else
{
return true;
}
}
}
现有表单标记
<form name="myForm" action="http://foo.com" method="post" onsubmit="return formCheck();">
现有电子邮件输入字段
<input type="text" class="form-text" name="email" id="recipientEmail">
现有提交按钮
<input type="image" src="some_pic.gif" alt="OK" id="submit_form" onclick="document.onlineForm.submit();" value="send" name="submit_button">
现在,只要我点击提交按钮,表单就会被提交,我的Javascript似乎被忽略了。我做错了什么?
答案 0 :(得分:3)
当您通过直接调用“submit()”提交表单时,就像您的按钮正在执行一样,不会调用“onsubmit”处理程序。
您可以让提交按钮调用另一个功能:
function doSubmit() {
if (formCheck()) document.myForm.submit();
}