我使用以下方式,请求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)
。
但是对我来说没有任何作用,对此有什么正确的片段吗? 我怎样才能做到这一点?提前谢谢。
答案 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>