仅当jquery函数为true时才使用表单操作url

时间:2018-12-18 20:39:02

标签: javascript jquery html forms

我一直在寻找时间,并尝试在此处和其他地方找到其他代码示例,但似乎没有任何效果。

如果电子邮件字段既不是空白也不是无效的,我只希望我的表单转到操作网址。如果不是,除了显示我的错误消息外,我什么也不想发生。这是我当前使用的脚本,但是当单击我的“取消订阅”按钮时,无论如何似乎都可以转到操作网址。

function isEmail(email) {
var regex = /^([a-zA-Z0-9_.+-])+\@(([a-zA-Z0-9-])+\.)+([a-zA-Z0-9] . 
{2,4})+$/;
return regex.test(email);
}






function validateForm() {
if( !isEmail( document.getElementById('email_address').value ) ) { 
  var err = document.getElementById('error');
   err.show();
  $( "#submit" ).click(function( event ) {
event.preventDefault();
    return false;
 } else { 
    return true;
 }    
 }

并且html看起来像这样

    <p id="error">Please enter your email address</p>

<form id="myForm" method="post" 
action="https://fe3e15707564057a7d1470.pub.s10.sfmc- 
content.com/tfuryofct5y? 
optc=%%=v(@optc)=%%&brand=%%=v(@brand)=%%&ceid=%%=v(@ceid)=%%" 
  onsubmit="return validateForm();">

<input type="text" placeholder="email address" name="email_address" 
id="email_address" align="center"/>

<p style="text-align:center;overflow:hidden;float:right;padding- 
right:8em;">
  <input id="submit" type="submit" value="Unsubscribe" ></p>
 </form>

jQuery不是我的强项,因此可能相距甚远。

1 个答案:

答案 0 :(得分:0)

您正在混合使用javascript和jquery并导致onclick提交表单。

function validateForm() {
   var err = $('#error');
   if( !isEmail( document.getElementById('email_address').value ) ) {       
      err.show();
      return false;
   } else {
      err.hide();
      return true;
   }
}