Кафедра ИСиТ УО ВГТУ
  • Специальности
    • Экономика электронного бизнеса
    • Информационные системы
    • Information Control Systems
  • Каталог
  • Сайт кафедры
  • Сервисы
    • GitLab
    • ownCloud
    • JupyterHub
    • JupyterHub 2
    • VNC
    • Soft
  1. ИСиТ
  2. РВПсИПП
  3. Практика
  4. Лаб. работа 4 “Создание индексных страниц и пагинация”
  • ИСиТ
    • АОС
      • Теория
        • Введение в операционные системы
        • Управление памятью
        • Управление процессами
        • Система ввода-вывода
        • Информационная безопасность
        • Виртуализация
      • Практика
    • РВПсИПП
      • Теория
        • Настройка среды разработки для PHP
        • Разработка web-приложений на базе фреймворков
        • Основы Laravel
        • Шаблоны в Laravel
        • Модели и базы данных в Laravel
        • Формы и валидация в Laravel
        • Аутентификация и авторизация в Laravel
        • Создание REST API в Laravel
        • Работа с файлами и изображениями в Laravel
        • Тестирование и отладка в Laravel
        • Введение в фреймворк Symfony
        • Маршруты и контроллеры в Symfony
        • Шаблоны и Twig в Symfony
        • Формы и валидация в Symfony
        • Доступ к базам данных в Symfony
        • Аутентификация и авторизация в Symfony
        • Сервисы и зависимости в Symfony
        • Создание REST API в Symfony
        • Работа с файлами и медиа в Symfony
        • Сравнение и выбор фреймворка
        • Развертывание веб-приложения
      • Практика
        • Лаб. работа 1 “Создание нового приложения Laravel”
        • Лаб. работа 2 “Добавление главной страницы и базовых маршрутов”
        • Лаб. работа 3 “Создание моделей, миграций и сидеров”
        • Лаб. работа 4 “Создание индексных страниц и пагинация”
        • Лаб. работа 5 “Создание форм для работы с сущностями”
        • Лаб. работа 6 “Работа с файлами (эмуляция S3-хранилища)”
        • Лаб. работа “Создание маршрутов в Laravel”
        • Лаб. работа “Работа с базами данных в Laravel”
        • Лаб. работа “Работа с формами в Laravel”
        • Лаб. работа “Аутентификация и авторизация в Laravel”
        • Лаб. работа “Работа с файлами в Laravel”
        • Лаб. работа “Тестирование и оптимизация в Laravel”
        • Лаб. работа “Создание REST API в Laravel”
        • Лаб. работа “Основы Symfony”
        • Лаб. работа “Шаблоны и представления в Symfony”
        • Лаб. работа “Работа с базами данных в Symfony”
        • Лаб. работа “Фомы и аутентификация в Symfony”
        • Лаб. работа “Сервисы и зависимости в Symfony”
        • Лаб. работа “REST API в Symfony”
        • Лаб. работа “Работа с медиа контентом в Symfony”
        • Лаб. работа “Создание и развертывание проекта”
    • ПСП
      • Теория
        • Введение
        • Протокол HTTP
        • Программирование с использованием сокетов
        • Введение в PHP
        • Работа с базами данных в PHP
        • Объектно-ориентированные возможности PHP
        • Настройка среды разработки для PHP
        • Разработка web-приложений на базе фреймворков
      • Практика
        • Программное обеспечение
        • Регистрация в JupyterHub
        • Лаб. работа “Почтовые протоколы”
        • Лаб. работа “Протокол FTP”
        • Лаб. работа “Протокол HTTP”
        • Лаб. работа “Программирование сетевых приложений с использованием сокетов”
        • Лаб. работа “Основы PHP”
        • Лаб. работа “Массивы в PHP”
        • Лаб. работа “Создание веб-приложений с использованием Slim”
    • Компьютерные сети
      • Теория
        • Введение в компьютерные сети
        • Топологии сетей
        • Кодирование и мультиплексирование
        • Стеки протоколов
        • Адресация в компьютерных сетях
        • Система доменных имен (DNS)
        • Программирование с использованием сокетов
        • Введение в PHP
        • Протокол HTTP
        • Введение в компьютерные сети
      • Практика
        • Программное обеспечение
        • Регистрация в JupyterHub
        • Лаб. работа “Почтовые протоколы”
        • Лаб. работа “Протокол FTP”
        • Лаб. работа “Протокол HTTP”
        • Лаб. работа “Программирование сетевых приложений с использованием сокетов”
        • Лаб. работа “Основы PHP”
        • Лаб работа “Массивы в PHP”
    • РиОИИС
      • Теория
        • Классификация оптимизационных задач
        • Генетические алгоритмы
        • Системы массового обслуживания
        • Теория игр
        • Машинное обучение
        • Глубокое обучение (Deep learning)
        • Основы функционального программирования
        • Основы программирования на Haskell
        • Введение в логическое программирование
        • Инференция и рассуждения в логическом программировании
        • Разработка экспертных систем
        • Интеллектуальные системы и их архитектура
        • Веб-скрэйпинг
        • Сбор данных с открытых API
      • Практика
        • JupyterHub
        • Лаб. работа “Методы одномерной оптимизации”
        • Лаб. работа “Методы многомерной оптимизации”
        • Лаб. работа “Функции в Python”
        • Лаб. работа “Рекурсия в Python”
        • Лаб. работа “Итераторы в Python”
        • Лаб. работа “Генетические алгоритмы”
        • Лаб. работа “Haskell”
        • Лаб. работа “Логическое программирование”
        • Лаб. работа “Сбор данных с помощью веб-скрейпинга”
    • КСКР
      • Практика
        • Лаб. работа “Одномерные и двумерные массивы в C#”
        • Лаб. работа “Обращение матриц в C#”
    • Системное программирование
      • Теория
        • Управление памятью в Windows
        • Файловые операции в Windows
        • Управление процессами в Windows
        • Графический интерфейс Windows
        • ОС Unix
      • Практика
        • Лаб. работа “Работа с динамической памятью в Windows”
        • Лаб. работа “Операции с файлами в Windows”
        • Лаб. работа “Управление процессами в Windows”
        • Лаб. работа “Работа с виртуальной машиной Linux”
        • Лаб. работа “Язык командного энтерпритатора Shell”
        • Лаб. работа “Работа с файлами в Linux”
        • Лаб. работа “Работа с процессами в Linux”

Содержание

  • Методическая часть
  • Индивидуальные задания
  • Примечания
  1. ИСиТ
  2. РВПсИПП
  3. Практика
  4. Лаб. работа 4 “Создание индексных страниц и пагинация”

Лаб. работа 4 “Создание индексных страниц и пагинация”

Разработка web-приложений с использованием программных платформ
Практика
Автор

Бизюк Андрей

Дата публикации

27 февраля 2025 г.

Цель: Научиться выводить данные из БД на страницы приложения, реализовать пагинацию и фильтрацию, использовать связи между моделями.
Задачи:
- Создать страницу со списком постов.
- Реализовать пагинацию и сортировку.
- Отображать связанные данные (категории, теги, комментарии).
- Стилизовать интерфейс с использованием Tailwind CSS.


Методическая часть

1. Создание контроллера и маршрута

  1. Создайте контроллер PostController, если он не создан ранее:

    php artisan make:controller PostController --resource
  2. Добавьте метод index в app/Http/Controllers/PostController.php:

    public function index() {
        $posts = Post::with(['category', 'tags', 'comments'])
                    ->orderBy('created_at', 'desc')
                    ->paginate(10);
        return view('posts.index', compact('posts'));
    }
  3. Зарегистрируйте маршрут в routes/web.php:

    use App\Http\Controllers\PostController;
    Route::get('/posts', [PostController::class, 'index'])->name('posts.index');

2. Создание Blade-шаблона

  1. Шаблон списка постов (resources/views/posts/index.blade.php):

    @extends('layouts.app')
    
    @section('content')
        <div class="max-w-7xl mx-auto px-4 sm:px-6 lg:px-8">
            <h1 class="text-3xl font-bold text-gray-900 mb-8">Все посты</h1>
    
            <!-- Фильтры и сортировка -->
            <div class="mb-6 flex justify-between items-center">
                <div class="flex space-x-4">
                    <a href="{{ route('posts.index', ['sort' => 'latest']) }}" 
                       class="px-4 py-2 bg-blue-600 text-white rounded-md hover:bg-blue-700">
                        Новые
                    </a>
                    <a href="{{ route('posts.index', ['sort' => 'popular']) }}" 
                       class="px-4 py-2 bg-gray-200 text-gray-700 rounded-md hover:bg-gray-300">
                        Популярные
                    </a>
                </div>
            </div>
    
            <!-- Список постов -->
            <div class="grid gap-6 md:grid-cols-2 lg:grid-cols-3">
                @foreach ($posts as $post)
                    <div class="bg-white rounded-lg shadow-md overflow-hidden">
                        @if ($post->image)
                            <img src="{{ asset('storage/' . $post->image) }}" 
                                 alt="{{ $post->title }}"
                                 class="w-full h-48 object-cover">
                        @endif
                        <div class="p-6">
                            <div class="flex items-center mb-2">
                                <span class="text-sm text-gray-600">
                                    {{ $post->created_at->format('d.m.Y') }}
                                </span>
                                <span class="mx-2">•</span>
                                <span class="text-sm text-blue-600">
                                    {{ $post->category->name }}
                                </span>
                            </div>
                            <h2 class="text-xl font-semibold text-gray-900 mb-2">
                                {{ $post->title }}
                            </h2>
                            <p class="text-gray-600 mb-4">{{ Str::limit($post->content, 150) }}</p>
                            <div class="flex items-center justify-between">
                                <div class="flex space-x-2">
                                    @foreach ($post->tags as $tag)
                                        <span class="px-2 py-1 bg-gray-100 text-gray-700 rounded-full text-sm">
                                            {{ $tag->name }}
                                        </span>
                                    @endforeach
                                </div>
                                <a href="{{ route('posts.show', $post) }}" 
                                   class="text-blue-600 hover:text-blue-800">
                                    Читать →
                                </a>
                            </div>
                        </div>
                    </div>
                @endforeach
            </div>
    
            <!-- Пагинация -->
            <div class="mt-8">
                {{ $posts->links() }}
            </div>
        </div>
    @endsection

3. Кастомизация пагинации

  1. Создайте файл пагинации для Tailwind:

    php artisan vendor:publish --tag=laravel-pagination
  2. Выберите шаблон resources/views/vendor/pagination/tailwind.blade.php.


4. Добавление сортировки в контроллер

Модифицируйте метод index для поддержки параметров:

public function index(Request $request) {
    $sort = $request->query('sort', 'latest');

    $query = Post::with(['category', 'tags', 'comments']);

    switch ($sort) {
        case 'popular':
            $query->withCount('comments')->orderBy('comments_count', 'desc');
            break;
        default:
            $query->orderBy('created_at', 'desc');
    }

    $posts = $query->paginate(10);
    return view('posts.index', compact('posts', 'sort'));
}

Индивидуальные задания

1. Фильтрация по категориям

  • Добавьте выпадающий список с категориями в шапку страницы.
  • Реализуйте фильтрацию постов по выбранной категории через параметр URL.

Пример кода:

<select onchange="window.location.href = '{{ route('posts.index') }}?category=' + this.value">
    <option value="">Все категории</option>
    @foreach ($categories as $category)
        <option value="{{ $category->id }}" {{ $category->id == request('category') ? 'selected' : '' }}>
            {{ $category->name }}
        </option>
    @endforeach
</select>

2. Поиск по заголовкам

  • Добавьте поле поиска, которое фильтрует посты по вхождению текста в заголовок.

  • Используйте LIKE в SQL-запросе:

    if ($search = $request->query('search')) {
        $query->where('title', 'LIKE', "%{$search}%");
    }

3. Бесконечная прокрутка

  1. Установите пакет для AJAX-пагинации:

    npm install axios
  2. Добавьте в конец шаблона:

    <div id="posts-container"></div>
    <div id="loading" class="hidden">Загрузка...</div>
    
    <script>
        let page = 1;
        const loadMore = async () => {
            page++;
            const response = await axios.get(`/posts?page=${page}`);
            document.getElementById('posts-container').innerHTML += response.data;
            if (!response.data.includes('paginator')) {
                window.removeEventListener('scroll', handleScroll);
            }
        };
    
        const handleScroll = () => {
            if (window.innerHeight + window.scrollY >= document.body.offsetHeight - 500) {
                loadMore();
            }
        };
    
        window.addEventListener('scroll', handleScroll);
    </script>

4. Статистика в сайдбаре

Добавьте блок с общей статистикой:

<div class="bg-white p-6 rounded-lg shadow-md">
    <h3 class="font-semibold mb-4">Статистика блога</h3>
    <ul class="space-y-2">
        <li>Всего постов: {{ Post::count() }}</li>
        <li>Всего комментариев: {{ Comment::count() }}</li>
        <li>Популярный тег: {{ Tag::withCount('posts')->orderBy('posts_count', 'desc')->first()->name }}</li>
    </ul>
</div>

Примечания

  • Оптимизация запросов: Используйте with() для жадной загрузки связанных данных.
  • Tailwind-классы: Для адаптивности применяйте grid-сетки (md:grid-cols-2, lg:grid-cols-3).
Наверх
Лаб. работа 3 “Создание моделей, миграций и сидеров”
Лаб. работа 5 “Создание форм для работы с сущностями”