我正在使用this site上找到的一些jQuery来创建联系表单。我遇到问题的部分是,当我提交一条错误消息时,它会显示错误消息。然后当我修复它时,它会显示成功消息以及错误消息。这是我正在使用的代码。
$(document).ready(function(){
$('#contact').submit(function(e){
e.preventDefault();
var name = $('.name-field').val();
var email = $('.email-field').val();
var text = $('.message-field').val();
var dataString = 'name=' + name + '&email=' + email + '&text=' + text;
function isValidEmail(emailAddress){
var pattern = new RegExp(/^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i);
return pattern.test(emailAddress);
};
if (isValidEmail(email) && (text.length > 1) && (name.length > 1)){
$.ajax({
type: 'POST',
url: 'contact-form.php',
data: dataString,
success: function(){
$('.result-success').fadeIn(1000);
}
});
}
else{
$('.result-error').fadeIn(1000);
}
return false;
});
});
$(document).ready(function(){
$('#contact .name-field').css('width', '100%').css('width', '-=24px');
$('#contact .email-field').css('width', '100%').css('width', '-=24px');
$('#contact .message-field').css('width', '100%').css('width', '-=24px');
});
我认为解决此问题的最有效方法是添加成功/错误消息的延迟淡出。有人能告诉我怎么做吗?
答案 0 :(得分:1)
你是对的。您可以像这样延迟消息淡出:
$('.result-success').fadeIn(1000);
//FadeOut after 2 seconds
setTimeout(function(){$('.result-success').fadeOut(1000);},2000);
答案 1 :(得分:0)
问题是您没有隐藏错误。 你可以这样做:
$('.result-error').fadeOut(1000);
在ajax调用的成功函数内
答案 2 :(得分:0)
你可以试试这个:
if (isValidEmail(email) && (text.length > 1) && (name.length > 1)){
$.ajax({
type: 'POST',
url: 'contact-form.php',
data: dataString,
success: function(){
$('.result-success').delay(10000).fadeIn('slow');
$('.result-error').hide();
}
});
}
else{
$('.result-error').delay(10000).fadeIn('slow');
}