Описание [Александр Ламков] [Stepik] Вёрстка сайта с нуля: JSX, SCSS, JS, Vite, Minista, БЭМ (2025):
Если вы уже знакомы с HTML, CSS и JavaScript, то самое время применить свои знания на практике!
Создайте фронтенд для веб-приложения, используя современные технологии. Вас ждёт много сложной вёрстки, тысячи строк качественного JavaScript-кода и уникальная сборка с JSX-шаблонизатором.
Это отличный проект для вашего портфолио и отличная тренировка перед тем, как погрузиться в изучение фронтенд-фреймворков.
Что вы узнаете и научитесь делать:
Разрабатывать сайты, используя современный стек технологий.
Создавать сложные UI-компоненты с помощью JavaScript, используя грамотно структурированный ООП-подход.
Использовать различные JavaScript API, такие как Proxy, ResizeObserver и MatchMedia.
Применять фреймворк Minista для ускорения процесса вёрстки.
Использовать современный сборщик проектов Vite для автоматизации рутинных действий.
Писать декомпозированную разметку в JSX синтаксисе.
Именовать классы элементов в разметке согласно методологии БЭМ.
Применять современные HTML-теги, такие как dialog, details, summary, dl, dt, dd, time и другие.
Оперировать современным синтаксисом CSS, включая Flex и Grid-сетки, адаптивные единицы измерения, псевдоклассы и необычные свойства.
Применять современные HTML-теги, такие как dialog, details, summary, dl, dt, dd, time и другие.
Оперировать современным синтаксисом CSS, включая Flex и Grid-сетки, адаптивные единицы измерения, псевдоклассы и необычные свойства.
Применять всю мощь препроцессора стилей Sass в синтаксисе SCSS.
Обрабатывать код пост-процессором стилей PostCSS и плагином postcss-pxtorem.
Работать с менеджером пакетов NPM.
Применять библиотеки Swiper, IMaskJS и classNames.
Анализировать макет в Figma.
Дебажить вёрстку в DevTools браузера.
Внедрять принципы доступности в код, используя 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 — настройка глобальной обертки каждой из страниц
- 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
- Секция MoviesBanner — MovieBannerCard, Slider (2 шага)
- Секция Collections — компонент Badge (2 шага)
- Секция Collections — компоненты MovieCard и RatingView (3 шага)
- Секция MovieBanner, доработка компонента MovieBannerCard
- Секция MovieDetails — компоненты PersonCard, ReviewCard (2 шага)
- Секция MovieDetails — компоненты Tags, Rating и PersonCard
- Секция MovieDetails — стилизация, Slider и SliderNavigation
- Секция ShowBanner
- Секция MovieDetails — Seasons, AccordionGroup, Accordion
- Секция MovieDetails, компоненты Seasons и EpisodeCard (2 шага)
- Секция MovieDetails, JavaScript-модуль VideoPlayer
- Секция Support — компонент Field (2 шага)
- Секция Support — JavaScript-модуль InputMask
- Секция Support — компонент Checkbox
- Секция Support — компонент Select (разметка)
- Секция Support — компонент Select (стилизация)
- Секция Support — JavaSscript-модуль Select (2 шага)
- Секция PlansComparison — компонент Table
- Рефакторинг и исправление ошибок
- Сборка приложения
- Заключение
Для просмотра содержимого вам необходимо авторизоваться
Скачать курс [Александр Ламков] [Stepik] Вёрстка сайта с нуля: JSX, SCSS, JS, Vite, Minista, БЭМ (2025):
Для просмотра содержимого вам необходимо авторизоваться
Последнее редактирование модератором: