我一直在寻找时间,并尝试在此处和其他地方找到其他代码示例,但似乎没有任何效果。
如果电子邮件字段既不是空白也不是无效的,我只希望我的表单转到操作网址。如果不是,除了显示我的错误消息外,我什么也不想发生。这是我当前使用的脚本,但是当单击我的“取消订阅”按钮时,无论如何似乎都可以转到操作网址。
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不是我的强项,因此可能相距甚远。
答案 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;
}
}