我正在将我的 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 中添加一些内容以提示成功?谢谢你的帮助!