7

我正在将我的 DHTMLX 网格导出到 csv 并成功地创建了 .CSV 文件。我遇到的问题是它没有提示用户保存/打开文件。我正在使用来自 javascript 的 $.post 调用将 CSV 字符串发送到 PHP,然后将该字符串写入 csv。由于某种原因,它没有为用户创建提示,但它成功地写入文件并保存在服务器上。下面是相关代码:

JS:

myGrid.csvParser = myGrid.csvExtParser;
myGrid.setCSVDelimiter('|');
myGrid.csv.row = "endOfRow";           
var gridCsvData = myGrid.serializeToCSV();

    $.post(
        "data/export.php", 
        { 
           csvdata: gridCsvData
        }
    );

PHP(导出.php):

$csvData = $_REQUEST['csvdata'];

$csv = explode('endOfRow',$csvData);

$myfile = "grid.csv";

$fh = fopen($myfile, 'w') or die("can't open file");

foreach($csv as $line) {
    fputcsv($fh, explode('|',$line),',','"');
}

fclose($fh);

//Redirect output to a client's web browser (csv)
header("Content-type: application/csv");
header("Content-Disposition: attachment; filename=grid.csv");
header("Pragma: no-cache");
header("Expires: 0");

这段代码完美地工作在它完全按照我想要的方式导出网格并将其保存到“grid.csv”的意义上。问题是它没有提示用户保存文件。这是我的 PHP 标头的问题,还是我需要在 $.post 中添加一些内容以提示成功?谢谢你的帮助!

4

2 回答 2

14

您不能提示用户从 AJAX 调用下载文件。您可以做的一件事是,制作一个 iFrame,在其中放入一个表单,然后发布它。这样,它看起来就像一个 AJAX 调用,但会提示用户下载文件。

// Create iFrame
var iframe = document.createElement('iframe');
iframe.style.display = "none";
document.body.appendChild(iframe);

// Get the iframe's document
var iframeDoc = iframe.contentDocument || iframe.contentWindow.document;

// Make a form
var form = document.createElement('form');
form.action = 'data/export.php'; // Your URL
form.method = 'POST';

// Add form element, to post your value
var input = document.createElement('input');
input.type = 'hidden';
input.name = 'csvdata';
input.value = gridCsvData;  // Your POST data

// Add input to form
form.appendChild(input);

// Add form to iFrame
// IE doesn't have the "body" property
(iframeDoc.body || iframeDoc).appendChild(form);

// Post the form :-)
form.submit();

PS您的PHP代码实际上并没有将CSV回显到屏幕上,它只是将其保存到一个文件中。

在标头调用之后,请确保您有:

readfile($myfile);
于 2012-08-23T18:55:47.603 回答
2

在 HTML5 中执行此操作的正确方法是使用 File API。有关详细信息,请参阅: http: //hackworthy.blogspot.com/2012/05/savedownload-data-generated-in.html

如果 HTML5 不是一个选项,那么采用这种方法。

执行 POST 后,使用以下命令生成文件的 GET 请求:

document.location = "file.csv";

根据浏览器的不同,文件将被保存 (Chrome),或者将提示用户选择要另存为的文件名。当然,POST 处理程序必须将文件保存在某处。

$.ajax({
    type: "POST",
    url: "post.php",
    success: function() {
        console.log("Worked!");
        document.location = "test.csv";
    },
    error: function() {
        console.log("Failed!");
    }
});
于 2012-08-23T19:50:21.870 回答