JQuery - 发送请求后绕过AJAX响应

时间:2016-06-20 05:23:48

标签: php jquery ajax response

我使用以下方式,请求PHP页面向许多用户发送邮件。我完全不需要回复。我想要的只是调用函数并开始在JS中做我的事情。

$.ajax({
  type    : 'POST',
  url     : 'mail_users.php',
  data    : formData,
  dataType: 'JSON',
  encode  : true
})
.done(function(data) {
  console.log(data);
})
.fail(function() {
  console.log("ERROR");
});

我还想确保请求正确完成。 我尝试了很多SO的建议,比如JS中的setTimeout()和PHP中的ignore_user_abort(true)set_time_limit(0)

但是对我来说没有任何作用,对此有什么正确的片段吗? 我怎样才能做到这一点?提前谢谢。

1 个答案:

答案 0 :(得分:1)

尝试提供帮助。我编写了一个代码,用于对URL进行AJAX调用。它包含回调函数,但您可以忽略(因为您不想检查结果)。请尝试使用此代码更改目标网址。

<强>结果

Tue Jun 21 2016 15:46:30 GMT-0300 (BRT) Req sent {"email_id":"1","key":"abc"}
Tue Jun 21 2016 15:46:30 GMT-0300 (BRT) Success
Tue Jun 21 2016 15:46:30 GMT-0300 (BRT) Complete {"readyState":4,"responseText":"\n\t\n\t\t\n\t\t\n\t\n\t\n\t\tResult:\n\t\t
\n\t\n","status":200,"statusText":"OK"}

<强>代码

<html>
    <head>
        <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script>
        <script>
            function log(msg) {
                var dateMsg = (new Date()) + ' ' + msg;
                var $res = $('#result');
                var $o = $('<li>').html(dateMsg);
                $res.append($o);
            }

            function checkEmailFrontEnd(email_id, key) {
                var userdata = {
                    email_id: email_id,
                    key: key
                };
                var opts = {
                    url: 'html.html',
                    type: 'POST',
                    data: userdata,
                    success: function(data, textStatus, jqXHR){
                        log('Success');
                    },
                    error: function(jqXHR, textStatus, error){
                        log('Error ' + error);
                    },
                    complete: function(jqXHR, textStatus){
                        log('Complete ' + JSON.stringify(jqXHR));
                    }
                };
                $.ajax(opts);   
                log('Req sent ' + JSON.stringify(userdata));
            }
            $(function(){
                checkEmailFrontEnd('1', 'abc');
            });
        </script>
    </head>
    <body>
        Result:
        <ul id='result'></ul>
    </body>
</html>