Drupal 7:使用Ajax刷新()多个响应

时间:2018-12-11 09:50:58

标签: php jquery ajax drupal flush

我有一个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之外达到完美。

1 个答案:

答案 0 :(得分:1)

万一有人遇到这个问题,我用

解决了
ob_end_flush(); 
ob_flush(); 
flush(); 
ob_start()

代替

flush();
ob_flush();

我希望有一天能对某人有所帮助!