搜尋
首頁php框架Laravel簡析Laravel-excel3.1的基礎用法

以下由Laravel教學專欄跟大家介紹Laravel-excel3.1最基礎用法,希望對大家有幫助!

  • 官網:https://docs.laravel-excel.com

路由定義為GET

Route::get('/export', [OrderController::class, 'export']);

控制器轉送

public function export(Request $request): BinaryFileResponse{
     return Excel::download(new OrderExport($request->get('status', -1)), 'order.xlsx');}

商業代碼

<?php

namespace App\Exports;

use App\Models\Order;
use Illuminate\Support\Collection;
use Maatwebsite\Excel\Concerns\FromCollection;
use Maatwebsite\Excel\Concerns\WithColumnFormatting;
use Maatwebsite\Excel\Concerns\WithHeadings;
use Maatwebsite\Excel\Concerns\WithMapping;
use PhpOffice\PhpSpreadsheet\Shared\Date;
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;

/**
 * 派单导出
 */
class OrderExport implements FromCollection, WithHeadings, WithColumnFormatting, WithMapping
{
    public $status;

    //接受参数
    public function __construct(int $status)
    {
        $this->status = $status;
    }

    /**
     * 数据源
     * @return Collection
     */
    public function collection(): Collection
    {
        $query = Order::query();
        if ($this->status != -1) {
            $query->where(&#39;status&#39;, $this->status);
        }
        return $query->get();
    }

    /**
     * 自定义表头
     * @return string[]
     */
    public function headings(): array
    {
        return [
            &#39;编号&#39;,
            &#39;创建人&#39;,
            &#39;中队长&#39;,
            &#39;人员&#39;,
            &#39;名称&#39;,
            &#39;备注&#39;,
            &#39;状态&#39;,
            &#39;创建时间&#39;,
            &#39;更新时间&#39;
        ];
    }

    /**
     * 设置单元格时间格式
     * @return array
     */
    public function columnFormats(): array
    {
        return [
            &#39;H&#39; => NumberFormat::FORMAT_DATE_YYYYMMDD,
            &#39;I&#39; => NumberFormat::FORMAT_DATE_YYYYMMDD,
        ];
    }

    /**
     * 自定义数据列
     * @param mixed $row
     * @return array
     */
    public function map($row): array
    {
        return [
            $row->id,
            $row->founder->name ?? &#39;无&#39;,
            $row->squadron->name ?? &#39;无&#39;,
            $row->player->name ?? &#39;无&#39;,
            $row->name,
            $row->remark ?: &#39;无&#39;,
            $this->statusMap($row->status),
            Date::dateTimeToExcel($row->created_at),
            Date::dateTimeToExcel($row->updated_at),
        ];
    }

    /**
     * 状态转化
     * @param $status
     * @return string
     */
    public function statusMap($status): string
    {
        switch ($status) {
            case 0:
                $statusText = &#39;待处理&#39;;
                break;
            case 1:
                $statusText = &#39;处理中&#39;;
                break;
            case 2:
                $statusText = &#39;待审核&#39;;
                break;
            case 3:
                $statusText = &#39;已完成&#39;;
                break;
            default:
                $statusText = &#39;未知&#39;;
        }
        return $statusText;
    }
}

相關建議:最新的五個Laravel影片教學                  

以上是簡析Laravel-excel3.1的基礎用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:learnku。如有侵權,請聯絡admin@php.cn刪除
最新的Laravel版本是什麼?最新的Laravel版本是什麼?May 09, 2025 am 12:09 AM

截至2023年10月,Laravel的最新版本是10.x。 1.Laravel10.x支持PHP8.1,提升了開發效率。 2.Jetstream改進支持Livewire和Inertia.js,簡化前端開發。 3.EloquentORM增加全文搜索功能,提升數據處理性能。 4.使用時需注意依賴包兼容性,並應用緩存優化性能。

Laravel遷移:數據庫管理初學者指南Laravel遷移:數據庫管理初學者指南May 09, 2025 am 12:07 AM

laravelmigrationsStreamLinedAtabasemagementbyByProvidingVersionControlforyourDatabaseschema.1)alloweryoutodefineandsharetherteructureofyourdatabase,MakeiteAsyTomanageChangEsovertime.2)MigrationalageChangangeSovertime.2)MigrationcancancanbecreatcanbecreateNdRununusingsImplecommands,Ensurantertatepeve

Laravel遷移:最佳編碼指南Laravel遷移:最佳編碼指南May 09, 2025 am 12:03 AM

Laravel的遷移系統是開發者進行數據庫設計和管理的強大工具。 1)確保遷移文件命名清晰明了,使用動詞描述操作。 2)考慮數據完整性和性能,如為字段添加唯一約束。 3)使用事務處理確保數據庫一致性。 4)在遷移最後創建索引以優化性能。 5)保持遷移的原子性,每個文件只包含一個邏輯操作。通過這些實踐,可以編寫高效、可維護的遷移代碼。

最新的Laravel版本:與最新功能保持最新最新的Laravel版本:與最新功能保持最新May 09, 2025 am 12:03 AM

Laravel的最新版本是10.x,發佈於2023年初。該版本帶來增強的EloquentORM功能和簡化的路由系統,提升了開發效率和性能,但升級時需謹慎測試以防引入問題。

掌握Laravel軟刪除:最佳實踐和高級技術掌握Laravel軟刪除:最佳實踐和高級技術May 08, 2025 am 12:25 AM

laravelsoftdeletesallow“刪除” withoutremovingRecordSssfromtheDatabase.toimplement:1)usethesoftdeletdeleterationyourmodel.2)usewithtrashed()toincludesoft-deletedrecordsinquordsinquordsinquordsinquordsinquordsinquordsinquordsinquordsinquordsinquordsinquor sinecustomscopemscopemscopeslikeonlikeOnlikeOnlikeOnlikeOnlikeNiqueniendselline)

Laravel軟刪除:恢復和永久刪除記錄Laravel軟刪除:恢復和永久刪除記錄May 08, 2025 am 12:24 AM

在Laravel中,恢復被軟刪除的記錄使用restore()方法,永久刪除使用forceDelete()方法。 1)恢復單個記錄使用withTrashed()->find()->restore(),多個記錄使用onlyTrashed()->restore()。 2)永久刪除單個記錄使用withTrashed()->find()->forceDelete(),多個記錄使用onlyTrashed()->forceDelete()。

當前的Laravel版本:今天下載和升級!當前的Laravel版本:今天下載和升級!May 08, 2025 am 12:22 AM

你應該下載併升級到最新的Laravel版本,因為它提供了增強的EloquentORM功能和新的路由特性,這些更新可以提高應用程序的效率和安全性。要升級,請按照以下步驟:1.備份當前應用程序,2.更新composer.json文件至最新版本,3.運行更新命令。雖然可能會遇到一些常見問題,如廢棄函數和包兼容性,但通過參考文檔和社區支持,這些問題都可以解決。

Laravel:我什麼時候應該更新到最後一個版本?Laravel:我什麼時候應該更新到最後一個版本?May 08, 2025 am 12:18 AM

youshouldupdateTotheLateStlaraverversionwhentheBeneFitsClearlyOutweighTheCosts.1)newfeaturesandimprovementCanenHanceCarenHanceYourApplication.2)SecurityUpdatesArecrucialifvulnerabilitysareaddresse.3)

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能