Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/288.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php jQuery联系人表单上的定时淡出_Php_Jquery - Fatal编程技术网

Php jQuery联系人表单上的定时淡出

Php jQuery联系人表单上的定时淡出,php,jquery,Php,Jquery,我正在使用我在上找到的一些jQuery创建一个联系表单。我遇到的问题是,当我提交一条错误消息时,它会显示一条错误消息。然后,当我修复它时,它会显示一条成功消息以及错误消息。这是我正在使用的代码 $(document).ready(function(){ $('#contact').submit(function(e){ e.preventDefault(); var name = $('.name-field').val(); var em

我正在使用我在上找到的一些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');
});
我认为解决这一问题的最有效方法是添加延迟的成功/错误消息淡出。有人能告诉我怎么做吗


问题在于您没有隐藏错误。 你可以做:

 $('.result-error').fadeOut(1000);

在ajax调用的success函数中,您是对的。您可以像这样延迟消息淡出:

$('.result-success').fadeIn(1000);
//FadeOut after 2 seconds
setTimeout(function(){$('.result-success').fadeOut(1000);},2000);
您可以尝试以下方法:

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');
    }

你能为这个提供提琴吗?如果你做`$('.result success').fadeIn('slow').delay(10000).fadeOut('slow'),就可以了;但我不记得“延迟”是否是一个阻塞函数