我有一个Drupal 7表单,在提交时,我通过Ajax这样调用PHP函数:
$('input[id*="edit-validate"]').click(function (e) {
var uploadcvPath = Drupal.settings.basePath + 'myfunction_submit';
$.ajax({
url: uploadcvPath,
data: $('form').serialize(),
xhrFields: {
onprogress: function (e) {
var thisResponse, response = e.currentTarget.response;
if (lastResponseLen === false) {
thisResponse = response;
lastResponseLen = response.length;
} else {
thisResponse = response.substring(lastResponseLen);
lastResponseLen = response.length;
}
jsonResponse = JSON.parse(thisResponse);
$('.ajax-res p').text('Processed ' + jsonResponse.count + ' of ' + jsonResponse.total);
$(".progress-bar").css('width', jsonResponse.progress + '%').text(jsonResponse.progress + '%');
}
},
success: function (response) {
alert('Success!!');
},
complete: function () {
//Hide loading container
alert('Done!!');
},
error: function (xmlhttp) {
alert('An HTTP error ' + xmlhttp.status + ' occurred.\n' + uploadcvPath);
},
});
e.preventDefault();
});
我想做的是返回响应以提供进度条,所以我的PHP函数如下所示:
function myfunction_submit() {
//First response
drupal_json_output(array('progress' => 50, 'count' => 50, 'total' => 50));
flush();
ob_flush();
sleep(2);
//Seconde response
drupal_json_output(array('progress' => 80, 'count' => 80, 'total' => 80));
flush();
ob_flush();
sleep(2);
}
这仅适用于第一个响应,但是当我添加第二个响应时,出现以下错误:
未捕获到的SyntaxError:意外令牌{在JSON中的位置37 在JSON.parse() 在XMLHttpRequest.onprogress
位置37对应于JSON响应中的第二个{
{"progress":1,"count":1,"total":2}{"progress":2,"count":2,"total":2}
表示Json格式无效。 我的问题是:Drupal 7中的flush()函数是否有问题?因为上面的代码可以在Drupal之外达到完美。
答案 0 :(得分:1)
万一有人遇到这个问题,我用
解决了ob_end_flush();
ob_flush();
flush();
ob_start()
代替
flush();
ob_flush();
我希望有一天能对某人有所帮助!