[Александр Ламков] [Stepik] Вёрстка сайта с нуля: JSX, SCSS, JS, Vite, Minista, БЭМ (2025)
Слив курса Вёрстка сайта с нуля: JSX, SCSS, JS, Vite, Minista, БЭМ [stepik] [Александр Ламков]
Уже знаете HTML, CSS и JavaScript?
Примените знания на практике — шаг за шагом разработайте фронтенд для веб-приложения на современном стеке технологий!
В курсе вас ждет много сложной вёрстки, тысячи строк качественного JavaScript-кода и крутейшая SSG-сборка с JSX-шаблонизатором на борту.
Достойный проект для портфолио и мощная тренировка перед тем, как погрузиться в дальнейшее изучение фронтенд-фреймворков!
Чему вы научитесь:
* Разрабатывать сайты на современном стеке технологий
* С помощью JavaScript реализовывать сложные UI-компоненты (Select, Tabs, Slider, VideoPlayer, InputMask, OverlayMenu) через грамотно структурированный ООП-подход (синтаксис классов, механика наследования от абстрактных классов, методы-геттеры и др.)
* Применять различные JavaScript API: Proxy, ResizeObserver, MatchMedia
* Использовать фреймворк Minista (SSG, Static Site Generator) для ускорения процесса вёрстки
* Использовать современный сборщик проектов Vite для автоматизации рутинных действий: обработка и минификация файлов стилей, обфускация скриптов, сжатие картинок, формирование SVG-иконок в спрайты
* Писать декомпозированную разметку в JSX синтаксисе (крайне полезная технология для тех, кто планирует в дальнейшем изучать React)
* Именовать классы элементов в разметке согласно БЭМ методологии
* Применять современные HTML-теги: dialog, details, summary, dl, dt, dd, time и др.
* Оперировать современным синтаксисом CSS: Flex и Grid-сетки, адаптивные единицы измерения (vw, vh, rem, em), псевдоклассы (has, nth, not, user-invalid, focus-visible), необычные свойства (appearance, column-count, break-inside, clip-path, grid-template-areas, grid-auto-flow, overscroll-behavior, display contents, transition-behavior), свойства-шорткаты (inset, inset-inline, padding-block, padding-inline, margin-inline), современный синтаксис медиазапросов, Scroll-driven Animations
* Применять всю мощь препроцессора стилей Sass в синтаксисе SCSS: миксины, функции, условия, переменные, директивы use и forward
* Обрабатывать код пост-процессором стилей PostCSS и плагином postcss-pxtorem для автоматического перевода единиц измерения пикселей в rem
* Работать с менеджером пакетов NPM (установка и использование сторонних зависимостей)
* Применять библиотеки Swiper, IMaskJS, classNames
* Анализировать макет в Figma
* Дебажить вёрстку в DevTools браузера
* Внедрять принципы Accessibility в код (WAI-ARIA и атрибуты role)
О курсе:
Цель курса — пошагово реализовать фронтенд многостраничного приложения стримингового сервиса, который состоит из 6 полноценных страниц со множеством секций и непростых UI компонентов.
Нам здесь встретятся такие компоненты интерфейса как табы, мобильное меню, открывающееся и закрывающееся при клике на кнопку “бургер”, кастомный видеоплеер, множество слайдеров, маски для полей ввода, а так же кастомный селект — всё это мы будем реализовывать с помощью ванильного JavaScript и используем мы лишь нескольких сторонних NPM-библиотек.
Классы элементов в разметке мы будем именовать по БЭМ-методологии, а для комфортного написания стилей мы будем использовать препроцессор стилей Sass на диалекте SCSS.
И вишенка на торте — мы будем использовать сборщик проектов Vite в обёртке в виде фреймворка Minista, где есть самая нужная нам функциональность — шаблонизатор разметки на основе синтаксиса JSX (да-да, тот самый, из мира React).
Пример того, что из себя представляют материалы курса — мой последний МК на YouTube. Только в этот раз — проект ещё более насыщенный, с весьма приятным стеком технологий, который значительно упрощает процесс разработки.
Для кого этот курс:
Начинающие фронтенд-разработчики, которые хотят попрактиковаться в применении ванильного JavaScript прежде, чем приступать к изучению более серьёзных технологий, таких как React / Vue / Angluar • Более опытные фронтенд-разработчики, которые хотят освоиться в современных возможностях HTML, CSS и JavaScript • Фронтенд-разработчики любого уровня, которые хотят научиться быстро и удобно разрабатывать MPA (многостраничные приложения) на современном стеке с помощью SSG (Static Site Generator) с шаблонизатором разметки на JSX-синтаксисе
Начальные требования:
Важно на базовом уровне знать HTML, CSS, JavaScript.
А так же желательно быть знакомым с метолологией БЭМ и препроцессором стилей Sass.
Программа курса:
Введение, подготовка папок и файлов
* Введение. Что будет в мастер-классе. Что нужно знать
* Сборщик проектов Vite и фреймворк Minista
* Установка Minista и библиотек. Настройка сборщика проектов
* Подготовка структуры папок проекта
* Файлы constants.scss и functions.scss — Sass-константы и функции
* Файл mixins.scss — Sass-миксины
* Файл media.scss — Sass-миксины для медиавыражений
* Файл helpers/index.js, автоподключение через сборщик проектов
* Подключение нормализации стилей
* Подключение шрифтов
* Файл variables.scss — подготовка глобальных CSS-переменных
* Файл utils.scss — подготовка утилитарных классов
* Файл globals.scss — подготовка глобальных стилей
* Шаблонизатор разметки JSX. Знакомство с синтаксисом. Особенности
* Файл global.jsx — настройка глобальной обертки каждой из страниц
Шапка и футер страницы (Header и Footer)
* Sticky эффект, применение scroll animation-timelineДемо-доступ
* Компонент Logo, библиотека classNames
* Меню навигации, списки в JSX, метод массивов map
* Компоненты Button и Icon, SVG-спрайты
* Компонент BurgerButton
* Меню-оверлей, HTML-элемент dialog, display contents
* JavaScript-модуль OverlayMenu
* Футер страницы — компоненты Socials и Button (доработка)
Главная страница
* Секция Hero, доработка Header
* Секция Categories — компонент Section
* Секция Categories — компоненты CategoryCard и Image
* Секция Categories — компоненты Slider и SliderNavigation
* Секция Categories — JavaScript-модуль SliderCollection (2 шага)
* Секция Devices — компоненты Grid и DeviceCard
* Секция Questions — компонент AccordionGroup
* Секция Questions — компонент Accordion
* Секция Plans — компоненты PlanCard и Button (доработка)
* Секция Plans — компоненты Tabs и TabsNavigation
* Секция Plans — JavaScript-модуль TabsCollection (2 шага)
* Абстрактный класс BaseComponent, Proxy API, доработка Tabs
* Секция Banner, доработка Content
Страница Movies
* Секция MoviesBanner — MovieBannerCard, Slider (2 шага)
* Секция Collections — компонент Badge (2 шага)
* Секция Collections — компоненты MovieCard и RatingView (3 шага)
Страница Movie (детальная страница фильма)
* Секция MovieBanner, доработка компонента MovieBannerCard
* Секция MovieDetails — компоненты PersonCard, ReviewCard (2 шага)
* Секция MovieDetails — компоненты Tags, Rating и PersonCard
* Секция MovieDetails — стилизация, Slider и SliderNavigation
Страница Show (детальная страница сериала)
* Секция ShowBanner
* Секция MovieDetails — Seasons, AccordionGroup, Accordion
* Секция MovieDetails, компоненты Seasons и EpisodeCard (2 шага)
* Секция MovieDetails, JavaScript-модуль VideoPlayer
Страница Support
* Секция Support — компонент Field (2 шага)
* Секция Support — JavaScript-модуль InputMask
* Секция Support — компонент Checkbox
* Секция Support — компонент Select (разметка)
* Секция Support — компонент Select (стилизация)
* Секция Support — JavaSscript-модуль Select (2 шага)
Страница Subscriptions
* Секция PlansComparison — компонент Table
Финал
* Рефакторинг и исправление ошибок
* Сборка приложения
* Заключение
—————————————————————————
🔗 Продажник:
Доступно пользователям: Зарегистрированный
📥 СКАЧАТЬ КУРС:
Для просмотра содержимого вам необходимо Войти или Зарегистрироваться.
🔐 Хотите получить доступ?
Чтобы увидеть скрытые ссылки и ставить лайки, активируйте VIP-статус.
💎 ПОЛУЧИТЬ ДОСТУП Наш Telegram канал