PHP / Laravel - Как я могу отображать заголовок таблицы на каждой странице печати?

Я использую Laravel 5.6 с maatwebsite(laravel-excel) 3.1 И моя версия php 7.1

Вот класс ОтчетЭкспорт:

<?php
namespace App\Exports;
use App\Report;
use Maatwebsite\Excel\Concerns\Exportable;
use Maatwebsite\Excel\Concerns\ShouldAutoSize;
use Illuminate\Contracts\View\View;
use Maatwebsite\Excel\Concerns\FromView;
use Maatwebsite\Excel\Concerns\WithEvents;
use Maatwebsite\Excel\Events\AfterSheet;
use PhpOffice\PhpSpreadsheet\Worksheet\PageSetup;
class ReportExport implements ShouldAutoSize, FromView, WithColumnFormatting, WithEvents
{
    use Exportable;
    protected $id;
    public function __construct($id)
    {
        $this->id = $id;
    }
    public function view(): View
    {
        $report = Report::find($this->id);
        return view('exports.report', [
            'report' => $report,
        ]);
    }
    public function registerEvents(): array
    {
        return [
            AfterSheet::class    => function(AfterSheet $event) {
                $event->sheet->getDelegate()->getPageSetup()->setOrientation(PageSetup::ORIENTATION_LANDSCAPE);
                ...
            },
        ];
    }
}

Мой просмотр лезвия экспортирует laravel следующим образом:

<table>
    ...
    <thead>
    <tr>
        <th colspan = "2" rowspan = "2">No</th>
        <th colspan = "7" rowspan = "2">Mata Pelajaran</th>
        <th colspan = "17">Pengetahuan</th>
        <th colspan = "17">Keterampilan</th>
    </tr>
    <tr>
        <th colspan = "2">KB</th>
        <th colspan = "3">Angka</th>
        <th colspan = "3">Predikat</th>
        <th colspan = "9">Deskripsi</th>
        <th colspan = "2">KB</th>
        <th colspan = "3">Angka</th>
        <th colspan = "3">Predikat</th>
        <th colspan = "9">Deskripsi</th>
    </tr>
    </thead>
    <tbody>
    ...
    @php ($group = 'A')
    @php ($number = 0)
    @foreach($values as $item)
    @if ($number==0 || $group!=$item['group'])
    <tr>
        <td colspan = "9">Kelompok {{$item['group']}}</td>
        <td colspan = "2"></td>
        <td colspan = "3"></td>
        <td colspan = "3"></td>
        <td colspan = "9"></td>
        <td colspan = "2"></td>
        <td colspan = "3"></td>
        <td colspan = "3"></td>
        <td colspan = "9"></td>
    </tr>
    @php ($number = 0)
    @endif
    <tr>
        <td colspan = "2">{{++$number}}</td>
        <td colspan = "7">{{$item['lesson_name']}}</td>
        <td colspan = "2">{{$item['kb_pengetahuan']}}</td>
        <td colspan = "3">{{$item['nilai_pengetahuan']}}</td>
        <td colspan = "3">{{$item['predikat_pengetahuan']}}</td>
        <td colspan = "9">{{$item['deskripsi_pengetahuan']}}</td>
        <td colspan = "2">{{$item['kb_keterampilan']}}</td>
        <td colspan = "3">{{$item['nilai_keterampilan']}}</td>
        <td colspan = "3">{{$item['predikat_keterampilan']}}</td>
        <td colspan = "9">{{$item['deskripsi_keterampilan']}}</td>
    </tr>
    @php ($group = $item['group'])
    @endforeach
    </tbody>
</table>

Скрипт работает. Но если я вижу в предварительном просмотре, заголовок таблицы отображается только на странице 1. Я хочу, чтобы заголовок таблицы отображался на всех страницах.

Как мне это сделать?

Неужели нет никого, кто мог бы мне помочь?

Success Man 07.06.2019 09:29
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
1
1
1 268
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Поскольку вы используете лезвие здесь, вам нужно повторить заголовок в зависимости от условия для разделения каждой страницы. Как и сколько записей вы хотели бы отобразить на странице.

Лучше создать это как подпредставление и включить заголовок на основе условия. Я имею в виду после количества строк (на основе отрегулированного пространства на странице).

Вот документация по использованию подвидов — https://laravel.com/docs/5.8/blade#включая-подвиды

Если вы используете для создания Excel из записи, вы можете использовать этот подход.

Установить повторение строк сверху при печати - PHPExcel

Дайте мне знать, если это поможет.

Ваш ответ: $objPHPExcel->getActiveSheet()->getPageSetup()->setRowsToRep‌​eatAtTopByStartAndEn‌​d(1,1);. Можно ли добавить условия только на страницы 1, 2 и 3, которые отображают заголовок таблицы. Нет другой страницы. У меня есть несколько таблиц. Если я использую этот ответ, появятся все страницы

Success Man 06.06.2019 23:36

Мне жаль. Я снимаю отметку с вашего ответа. Потому что я все еще нахожу проблемы, как я объяснил выше

Success Man 07.06.2019 09:24

в чем проблема сейчас?

Vikash Pathak 07.06.2019 09:33

Я просто хочу повторить заголовок таблицы на страницах 1, 2 и 3. Я не хочу повторять заголовок таблицы на страницах 4.5 и 6.

Success Man 07.06.2019 09:37

@SuccessMan в своем вопросе, который вы указали для all pages, и решение было соответствующим этому ... теперь ваше требование изменилось, и вы не принимаете решения. Не совсем хорошо :)

Vikash Pathak 07.06.2019 09:41

Однако вы можете передать индекс листа, если это поможет... например, $objPHPExcel->getActiveSheet(0) для первого листа... и для второго `$objPHPExcel->getActiveSheet(1)` что-то вроде этого.

Vikash Pathak 07.06.2019 09:43

Другие вопросы по теме