На главную

Программа курса

Полная программа

Подробная структура курса: модули, ключевые темы и практический фокус каждого блока.

Модуль 1

Фундаментальные знания

Самый важный блок курса. Это фундамент, на котором строится архитектура любого приложения независимо от стека, фреймворка и методологии. Цель модуля - перестать слепо повторять чужие правила и начать мыслить системно: понимать, почему код устроен именно так, а не иначе.

1.1. SOLID в контексте React

SOLID разбирается не как набор абстрактных правил, а как ориентиры для проектирования React-кода. Смотрим, где нарушение принципов действительно бьет по скорости разработки и поддержке, а где усложнение не оправдано.

  • S - Single Responsibility Principle: разделение ответственности между хуком, view-компонентом и контейнером
  • O - Open/Closed Principle: расширяемые компоненты через композицию и slot-подход вместо флагов-пропсов
  • L - Liskov Substitution Principle: подстановка типов и работа с нативными HTML-атрибутами через ComponentProps
  • I - Interface Segregation Principle: прозрачные пропсы и влияние интерфейсов на читаемость кода в команде
  • D - Dependency Inversion Principle: отвязка компонентов от backend, localStorage, IndexedDB, Supabase, Firebase и конкретного state management

1.2. MV*-паттерны: MVC / MVP / MVVM

Этот блок дает понимание, откуда вообще берется разделение на слои и роли. После него React, Vue и Angular перестают восприниматься как принципиально разные миры и собираются в единую архитектурную картину.

  • MVC и MVP: теория, презентация и разбор реализации на практическом проекте
  • MVVM: теория, Excalidraw-схема и реализация на практическом проекте
  • Роли и связи между слоями: View, Model, Presenter, ViewModel
  • Data-binding через Proxy: как реактивность работает под капотом

1.3. Сборка фундамента под React

Флагманское видео модуля, где все идеи соединяются в работающую архитектуру на React. Здесь теория перестает быть теорией и собирается в цельную систему, пригодную для реального проекта.

  • DIP и Dependency Injection на практике
  • Composition Root
  • Архитектурные роли во Frontend
  • Инфраструктурный код
  • DI через props и React.Context
  • Основы тестируемости архитектуры
  • Репозиторий с кодом, Excalidraw-доска, разбор render props и обзор структуры папок

После модуля ты

  • Проектируешь компоненты, которые переживают смену стейт-менеджера и источника данных без переписывания
  • Видишь архитектуру фреймворков через общие роли и слои, а не через синтаксис конкретной технологии
  • Понимаешь, почему архитектурные методологии устроены именно так, и где от них можно осознанно отступать

Модуль 2

Основная часть. Архитектура React-приложения от хаоса до production

В этом модуле ты разрабатываешь одно приложение в нескольких архитектурных итерациях. Каждая итерация решает конкретную проблему предыдущей и сравнивает подходы, технологии и стейт-менеджеры. Главная мысль модуля: архитектура важнее стека. Любой инструмент вторичен, если выстроены слои, границы и направление зависимостей.

2.1. Архитектурный скелет: от чистого React к слоистой системе

Базовая итерация приложения, на которой ставятся слои и направление зависимостей. Здесь становится видно, что чистый React при правильной архитектуре не уступает решениям с тяжелым стеком.

  • Рефакторинг стартового приложения: структура папок, инфраструктурный код, DI
  • Слои Service / Model / ViewModel / View / Composition Root
  • Архитектурные границы через роутинг
  • Инфраструктурный код, который держит чистоту даже на голом React + Context
  • Contract-first API и автогенерация DTO (orval)
  • Визуализация связей модулей на Excalidraw

2.2. Подбор стейт-менеджера и его роль в архитектуре

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

  • Zustand: правильное хранение бизнес-логики и роль Model
  • Service Locator: безопасное использование через Module Composition Root
  • Оптимизация ре-рендеров: селекторы, инкапсуляция состояния, children-пропсы
  • Global / Module / Local Composition Root
  • Preact/signals и HOC для работы с Service Locator
  • Effector: бизнес-логика как граф событий, паттерн Gateway из DDD
  • Reatom: философия и почему он сильнее аналогов на сложных проектах
  • Inversion of Control, Builder Pattern, Identify из LIFT
  • Высокоуровневые vs низкоуровневые модули
  • Самописный Zustand на useSyncExternalStore и fine-grained reactivity

2.3. Масштабирование архитектуры при росте сложности

Отдельный блок про то, когда паттерны действительно нужны, а когда только усложняют систему. Все решения привязываются к реальным проблемам сложности, а не к моде на конкретный подход.

  • Эволюция структуры папок и data flow по мере роста проекта
  • Как я реально использую FSD на боевых проектах
  • Bounded Context на практике
  • Когда внедрять микрофронтенды, а когда нет
  • Общение между модулями через Event Emitter
  • Module Federation для Vite и контроль зависимостей в host-приложении
  • Метрики сложности модуля

2.4. Одна фича - четыре реализации

Реалистичный сценарий про выбор уровня архитектуры под задачу и сроки. Одна и та же фича проходит путь от быстрого MVP до переиспользуемого решения для ui-kit.

  • Быстрое решение: когда "хорошо сейчас" важнее "идеально потом"
  • Модульная сборка зависимостей и продвинутый TypeScript для строгих API
  • Гибкое решение с привязкой к Reatom: AsyncWrapper, renderProp для списков
  • Перенос фичи в ui-kit на чистом React + reactuse
  • Паттерны slot и renderProp для композиции и подмены
  • Отвязка фичи от типов конкретного стейт-менеджера
  • Самописный DI-container и Poor man's DI: где он работает, где ломается

2.5. Глубокая теория State Management

Полный разбор стейт-менеджмента как класса задач, а не как набора библиотек. Этот блок помогает видеть общие принципы и понимать, зачем бизнес-логика должна жить вне UI.

  • Что такое State и какие виды состояния бывают
  • Виды стейт-менеджеров и их различия
  • Проблемы экосистемы React
  • Главная причина писать бизнес-логику вне UI
  • Проблемы технологий, прибитых гвоздями к React (на примере React Query)
  • Обоснование выбора Reatom для сложных проектов

2.6. Production-фичи: доводим приложение до боевого состояния

После архитектурного скелета добавляются вещи, которые отличают учебный проект от боевого: границы, права, обработка ошибок, optimistic UI и коммуникация между доменами.

  • JSON Server и переход к реалистичной работе с API
  • ESLint-плагин для контроля архитектурных границ
  • Optimistic UI на Reatom: транзакции, ACID, атомарность
  • Сравнение подхода с Optimistic Updates в Tanstack Query
  • Обработка ошибок через концепцию Fail Fast
  • Декларативная композиция через вспомогательные компоненты
  • Ролевая модель: проблема FSD-слоя entities и зачем нужен core
  • Авторизация vs аутентификация и защита модулей через Dependency Inversion
  • Компонент Can для декларативной работы с ролями
  • Cross-domain коммуникация и паттерн Facade
  • Сила чистых функций при cross-domain взаимодействии
  • Builder vs Adapter: разница на практике
  • Что произойдет, если выкинуть слой Service
  • Perceived Performance как метрика UX

2.7. Архитектура без IoC-контейнера

Реалистичный блок про ситуацию, когда идеальной инфраструктуры нет. На примере Tanstack Query разбирается, как чистая композиция и разделение бизнес-логики и UI работают даже на хуках.

  • Рефакторинг приложения на Tanstack Query
  • DI через самописный контейнер и через React.Context
  • Dependency Scopes
  • Public API модуля
  • Переход с классов на функции-фабрики и обоснование выбора синтаксиса

2.8. Работа с формами и аутентификация

Отдельный блок про формы - место, где архитектура чаще всего разваливается. Разбираем валидацию, auth-поток и разделение логики формы и UI.

  • React Hook Form: API, отличия от Formik
  • Zod: типобезопасная валидация и гибкие схемы для сложных форм
  • JWT Auth: теория и взгляд со стороны бэкенда
  • Реализация Axios-интерцепторов
  • Главная ошибка фронтендеров при работе с формами
  • Разделение логики формы и UI

2.9. Разработка Kanban-доски

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

  • Feature и Widget: что это и как различать
  • Page-first подход в проектировании страниц
  • Архитектура страницы проектов: атомизация в Reatom, чистая работа с формами через DI
  • Менеджер модальных окон: архитектурная проблема привязки форм к жизненному циклу React
  • Канбан-доска на dnd-kit: high cohesion внутри фичи, отделение типа домена от типа фичи
  • SSoT и атомарный стейт-менеджер для построения цепочек производных значений
  • CRUD для канбана: нормализация данных, проблема синхронизации React Router и React
  • Undo/Redo через паттерн Event Sourcing
  • Local-first как направление развития (референс - архитектура Linear)

После модуля ты

  • Проектируешь архитектуру React-приложения с нуля и обосновываешь каждое решение через trade-offs
  • Выбираешь стейт-менеджер под задачу, а не по моде, и понимаешь, как он диктует архитектуру
  • Пишешь чистый код одинаково на Reatom, Effector, Zustand и голом React - потому что мышление одно
  • Масштабируешь архитектуру под рост сложности проекта без переписывания
  • Доводишь фичи до production: optimistic UI, обработка ошибок, ролевая модель, cross-domain коммуникация