Heim > PHP-Framework > Laravel > Eine kurze Analyse der grundlegenden Verwendung von Laravel-excel3.1

Eine kurze Analyse der grundlegenden Verwendung von Laravel-excel3.1

藏色散人
Freigeben: 2021-12-28 15:40:54
nach vorne
1472 Leute haben es durchsucht

Die folgende Tutorial-Kolumne von Laravel wird Ihnen die grundlegendste Verwendung von Laravel-excel3.1 vorstellen. Ich hoffe, dass es für alle hilfreich sein wird!

  • Offizielle Website: https://docs.laravel-excel.com

Route::get('/export', [OrderController::class, 'export']);
Nach dem Login kopieren

Controller-Weiterleitung

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

Geschäftscode

<?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;
    }
}
Nach dem Login kopieren

Zugehörige Empfehlung: Die neuesten fünf Laravel-Video-Tutorials


🎜 🎜🎜 🎜

Das obige ist der detaillierte Inhalt vonEine kurze Analyse der grundlegenden Verwendung von Laravel-excel3.1. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:learnku.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage