Зарегистрируйтесь, чтобы продолжить обучение

Контроллер PHP: Разработка на Laravel

Реализация CRUD – самый быстрый способ познакомиться с любым веб-фреймворком. Он затрагивает все основные его части и позволяет понять насколько в этом фреймворке удобно работать.

Создать CRUD в Laravel можно несколькими способами. Самый простой – добавить в файл маршрутизации нужные маршруты вместе с обработчиками. Внутри обработчиков реализовать логику вывода списка, создания, обновления и удаления статьи. Этот способ очень муторный, он требует много движений от программиста. И он быстро захламляет файл с маршрутами. Когда таких "крудов" станет хотя бы несколько штук, то ориентироваться в нем станет проблематично. А если добавить сотню другую как в реальных проектах, так вообще станет невозможно.

Проблема одного файла решается с помощью "контроллера". В Laravel контроллером называют класс, который расположен в директории app/HTTP/Controllers. Методы этого класса связываются с конкретными маршрутами и отвечают за их обработку:

<?php
// routes/web.php

// Вторым параметром передается массив: '[controllerClass, methodName]'
Route::get('about', [PageController::class, 'about']);
Route::get('team', [PageController::class, 'team']);

// app/HTTP/Controllers/PageController.php

namespace App\Http\Controllers;

// Должен наследоваться от Controller
class PageController extends Controller
{
    public function about()
    {
        // Точка используется вместо /.
        // То есть шаблон находится по пути resources/views/page/about.blade.php
        return view('page.about');
    }

    public function team()
    {
        return view('page.team');
    }
}

Методы в контроллерах принято группировать по смысловой связи. Например, все, что относится к обычным страницам на сайте можно поместить в контроллер PageController, а CRUD для статей — в контроллер ArticleController. Ниже пример структуры контроллеров из нашего открытого проекта hexlet-sicp:

app/Http/Controllers/
├── Auth
│   ├── ForgotPasswordController.php
│   ├── LoginController.php
│   ├── RegisterController.php
│   ├── ResetPasswordController.php
│   ├── Social
│   │   └── GithubController.php
│   └── VerificationController.php
├── Controller.php
├── HomeController.php
├── MyController.php
├── RatingController.php
├── UserChapterController.php
└── UserController.php

Еще одно соглашение — расположение шаблонов. Шаблоны одного контроллера лучше группировать вместе, в одной директории. В примере выше, все шаблоны страниц расположены по пути resources/views/page. Это позволяет удобнее ориентироваться в шаблонах и избегать коллизий имен.

Контроллеры, так же как и модели, не нужно создавать руками. Их можно генерировать через artisan:

php artisan make:controller PageController

Controller created successfully.

А вот шаблоны и методы контроллера придется добавлять самостоятельно.


Самостоятельная работа

  1. Перенесите обработчик about в контроллер PageController. Убедитесь, что страница открывается.

Дополнительные материалы

  1. Controller

Аватары экспертов Хекслета

Остались вопросы? Задайте их в разделе «Обсуждение»

Вам ответят команда поддержки Хекслета или другие студенты

Для полного доступа к курсу нужен базовый план

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

Получить доступ
1000
упражнений
2000+
часов теории
3200
тестов

Открыть доступ

Курсы программирования для новичков и опытных разработчиков. Начните обучение бесплатно

  • 130 курсов, 2000+ часов теории
  • 1000 практических заданий в браузере
  • 360 000 студентов
Отправляя форму, вы принимаете «Соглашение об обработке персональных данных» и условия «Оферты», а также соглашаетесь с «Условиями использования»

Наши выпускники работают в компаниях:

Логотип компании Альфа Банк
Логотип компании Aviasales
Логотип компании Yandex
Логотип компании Tinkoff
Рекомендуемые программы
профессия
Программирование на PHP, Разработка веб-приложений и сервисов используя Laravel, проектирование и реализация REST API
10 месяцев
с нуля
Старт 23 января

Используйте Хекслет по-максимуму!

  • Задавайте вопросы по уроку
  • Проверяйте знания в квизах
  • Проходите практику прямо в браузере
  • Отслеживайте свой прогресс

Зарегистрируйтесь или войдите в свой аккаунт

Отправляя форму, вы принимаете «Соглашение об обработке персональных данных» и условия «Оферты», а также соглашаетесь с «Условиями использования»