0

我正在使用 ajax 函数来发送数据。在 php 进程中,我运行 phpmailer 以使用 smtp gmail 发送电子邮件。一切都很顺利,但在某些情况下,我想向用户提供信息以等待正在进行的过程。我的代码:

LoadingProccess();
var FormData = $('#subscribe').serialize(); 
$.ajax({
    type: "POST",
    url: "proses_corporate.php",
    data: FormData,
    cache: false,
    dataType: "json",
    success: function(data){
        var cek = data.result;
        $.unblockUI();
        if(cek=='Success'){
        $('#subscribe')[0].reset();
        $.blockUI({ 
            message:  '<h4>'+data.status+'</h4>', 
            timeout:   8000 ,
            css: {
              top:  ($(window).height() - 100) /2 + 'px', 
              left: ($(window).width() - 650) /2 + 'px',
              width: '650px'
        }); 
            setTimeout(function() { 
                window.location.href = 'http://www.domain.com/';
            }, 8000);
    }
      setTimeout(function() { 
          window.location.href = 'http://www.domain.com/';
      }, 8000);
    }
   },
         error: function() {
            alert('Error');
         }

});

场景:当我提交时,应用程序将被锁定并向用户显示该过程正在进行的信息。因为那个 php 需要几秒钟来处理通过 smtp gmail 发送的邮件。

在我的 php echo json_encode 中给出命令给 jquery 以显示该过程已成功的信息。我的PHP代码:

function smtpmailer($to, $from, $from_name, $subject, $body) { 
    global $error;
    $mail = new PHPMailer();  // create a new object
    $mail->IsSMTP(); // enable SMTP
    $mail->SMTPDebug = 0;  // debugging: 1 = errors and messages, 2 = messages only
    $mail->SMTPAuth = true;  // authentication enabled
    $mail->SMTPSecure = 'ssl'; // secure transfer enabled REQUIRED for GMail
    $mail->Host = 'smtp.gmail.com';
    $mail->Port = 465; 
    $mail->Username = GUSER;  
    $mail->Password = GPWD;           
    $mail->SetFrom($from, $from_name);
    $mail->Subject = $subject;
    $mail->Body = $body;
    $mail->AddAddress($to);
    if(!$mail->Send()) {
        $error = 'Mail error: '.$mail->ErrorInfo; 
        return $error;
    } else {
        $error = 'Message sent!';
        return $error;
    }
}

使用

smtpmailer('bertho_joris@yahoo.co.id','berthojoris@gmail.com','GMAIL','Testing Form GMail','Test...Test...Test...Test...');
echo json_encode(array('status' => 'Data has been sent.', 'result' => 'Success'));

如上面的代码,表单将在成功处理后被路由到特定页面。就我而言,jQuery 如何在翻页之前等待动态 php 的结果?

你必须在 jQuery 上使用timeout: 10000吗?它似乎不是动态的,因为时钟是手动设置的。还有其他方法吗?

4

3 回答 3

0

您可以在页面上放置一个掩码并使其在 ajaxStart() 上可见并在ajaxStop()函数上消失或重定向页面

于 2013-04-02T08:45:11.060 回答
0

您可以使用 beforeSend 函数添加掩码。并在完成功能时移除遮罩。

于 2013-04-02T08:47:30.527 回答
0

您在等待响应时使您的 ajax 请求超时时间更长。例如

$.ajax({
    type: "POST",
    url: "proses_corporate.php",
    data: FormData,
    cache: false,
    timeout: 30000, // 3 second
    dataType: "json",
    success: function(res){   }, 
    failed: function(err){   }
}
于 2013-04-02T08:57:19.050 回答