簡體   English   中英

通過按鈕單擊保存PhpSpreadSheet

[英]Saving a PhpSpreadSheet through button click

我正在嘗試讓我的Laravel應用程序下載帶有phpSpreadSheet的excel文件,這是PhpExcel的延續。 但到目前為止,我沒有任何運氣。 我首先嘗試通過onClick進行Axios調用,但由於不允許JS保存,因此無效。 之后,我嘗試將按鈕附加到Laravel動作,這只是打開一個空頁面。

我不知道這里是否有人能幫助我,但我會保持充滿希望

首先,您需要在路由中設置端點以使用ajax(在您的情況下為axios)來調用它:

Route::get('spreadsheet/download',[
   'as' => 'spreadsheet.download', 
   'uses' => 'SpreadsheetController@download'
]);

在你的控制器中:

public function download ()
{
    $fileContents = Storage::disk('local')->get($pathToTheFile);
    $response = Response::make($fileContents, 200);
    $response->header('Content-Type', Storage::disk('local')->mimeType($pathToTheFile));
    return $response;
}

如果您沒有該文件,可以將其保存到php:// output

public function download ()
{
    $writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($spreadsheet, "Xlsx");
    header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
    header('Content-Disposition: attachment; filename="file.xlsx"');
    $writer->save("php://output");
}

現在您只需要調用端點/spreadsheet/download即可開始下載,但正常的<a href="/spreadsheet/download">Download</a>可以正常工作。

希望這對你有所幫助。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM