0

我正在向客户展示一份报告。我进行了一个 ajax 调用,它传入了一个“delivery”变量,它可以是“display”或“download”。

这是ajax调用:

$.ajax({
        type: 'POST',
        url: 'ajaxController.php',
        dataType: 'json',
        data: {
            e: "getReport",
            reportName: reportName,
            delivery: delivery
        },
        success: function (data) {
            if (delivery === 'display') {
                $("#reportDisplayTableHeader").html('');
                $("#reportDisplayTableBody").html('');
                Lifestyle.selectedReportRows = data;

                $.each(Lifestyle.selectedReportRows, function(key, row) {
                    rowHTML = '<tr>';

                    $.each(row, function(parameter, value) {
                        if (isHeader) {
                            rowHTML += '<td>' + parameter + '</td>';
                        } else {
                            rowHTML += '<td>' + value + '</td>';
                        }
                    });

                    rowHTML += '</tr>';

                    if (isHeader) {
                        $reportHead.append(rowHTML);
                        isHeader = false;
                    } else {
                        $reportTableBody.append(rowHTML);
                    }
                });

                $("#reportCaption").show();
            }
        }
    });

这是服务器端PHP:

    if ($delivery == 'display') {
        echo json_encode($return);
    } else if ($delivery == 'download') {
        header("Content-type: text/csv");
        header("Content-Disposition: attachment; filename=file.csv");           
        header('Content-Description: File Transfer');
        header("Pragma: no-cache");
        header("Expires: 0");
        echo "record1,record2,record3\n";
    }

在“显示”的情况下,它返回 json 就好了,客户端显示一个表格。

在“下载”的情况下,我希望它弹出一个下载对话框,它可以保存我回显给他们的 CSV。

但是正在发生的事情是调用正在完成并且标头/ csv 正在越线(感谢 Fiddler),但是没有出现下载对话框,并且客户端不知道我将 csv 推送给了他们。

我需要做什么才能弹出下载对话框?

谢谢。

4

1 回答 1

1

Ajax 调用不能下载东西,或者至少它真的很难。更好的是打开一个新窗口到 php 文件的位置(然后你应该使用 GET),然后会提示用户下载它。

于 2013-08-16T16:21:43.303 回答