0

我很确定我想太多了,但我就是想不通。我有一个 dojo Button 对象,我想在单击它时执行一个 .php 文件。php 脚本运行一个查询并从中构造一个 .xls 文件,然后提示用户下载或打开该文件。

当我单击按钮时,我得到“加载的 xhrGet”日志,但提示从未出现,所以我不相信脚本实际上正在运行。

           <button  data-dojo-type="dijit.form.Button" id="export_xls_button">Export to .xls
                <script type="dojo/method" data-dojo-event="onClick" >
                    dojo.xhrGet({
                        url: 'subRoutines/exportXLS.php',
                        load: function(response){
                            console.debug("loaded xhrGet");
                        },
                        error: function(error){
                            console.debug("error loading xhrGet");
                        }
                    });
                </script>
            </button>

感谢您提供任何帮助或建议。

编辑:当我在网络浏览器中直接访问它并且在服务器上打开了 php 时,该脚本运行得很好。

4

1 回答 1

3

您不需要使用 XHR 来导出文件。您可以使用单击标准链接(或 dojo 按钮),单击该链接会执行subRoutines/exportXLS.php. 单击链接时,脚本会像正常一样构建文件,并将文件和相应的 http 标头发送回用户,而无需离开页面。没有新的位置标头被发送到浏览器,只是一个文件。

这是我用来在 PHP 中导出 CSV 文件的一种简单方法(您可能只需要标题):

$fh = fopen("php://output", 'w');
fputcsv($fh, $csv_headers_array, ",", '"');
foreach ($csv_content_array as $line) {
    fputcsv($fh, $line, ",", '"');
}
header("Content-type: text/csv");
header("Content-Disposition: attachment; filename=filename.csv");
fclose($fh);
exit; 

你的道场按钮变成这样:

<button data-dojo-type="dijit.form.Button" id="export_xls_button">
    Export to .xls
    <script type="dojo/method" data-dojo-event="onClick" >
        window.location = 'subRoutines/exportXLS.php';
    </script>
</button>
于 2012-09-04T00:31:13.137 回答