Front-end разработка
Путаница в вакансиях front-end developer, front end разработчик, фронтендщик, фронтенд девелопер, web developer, фронтенд-разработчик, веб-верстальщик — это не одно и тоже.
Фронтенд-разработчик не просто верстает макеты. Он хорошо знает JavaScript, разбирается во фреймворках и библиотеках (и активно юзает часть из них), понимает, что находится «под капотом» на серверной стороне. Его не пугают препроцессоры и сборщики LESS, SASS, GRUNT, GULP, он умеет работать с DOM, API, SVG-объектами, AJAX и CORS, может составлять SQL-запросы и копаться в данных. Также добавляются UI/UX-проектирование, адаптивная верстка, кросс-браузерность и кросс-платформенность, а иногда и навыков мобильной разработки.
front-end разработка — это создание клиентской части сайта. Front-end разработчик занимается версткой шаблона сайта и созданием пользовательского интерфейса. Обычно front-end разработчик — это мастер на все руки. Он просто обязан обладать талантом дизайнера, быть искусным верстальщиком и хорошим программистом.
Современный front-end developer должен легко владеть html5, css3, JavaScript (и как минимум JQuery). У каждого front-end специалиста есть свои наработки, которые он хранит в виде framework. Многие разработчики в работе пользуются популярными framework-ами, такими как: Twitter, Bootstrap, Foundation 3, Compass.
Что необходимо знать frond-end разработчику
В наши дни, чтобы быть успешным фронт-енд-разработчиком, нужно обладать набором необходимых базовых навыков. Те разработчики, которые не соответствуют этим требованиям, вскоре начнут отставать от динамичного прогресса, по мере того как источники информации начинают подразумевать наличие некоторых знаний как само собой разумеющееся.
Вот основные базовые навыки:
HTML и CSS
Для простого понимания HTML — это тело человека, а CSS — это одежда
В том числе сетки и CSS-фреймворки, спецификации W3C и WHATWG, HTML5/CSS3 Polyfills, HTML5 API
Существуют обычные редакторы для исходного кода и IDE — интегрированные среды разработки со множеством дополнительных функций и плюшек.
- Atom
- Visual Studio Code
- Brackets
- Sublime Text
- Notepad++
- Netbeans
- WebStorm
- Zend Studio
- Aptana
- Komodo IDE
HTML (HyperText Markup Language) говорит браузеру, каково содержание страницы, например, «заголовок», «параграф», «список», «элемент списка».
CSS (Cascading Style Sheets) говорит браузеру, как отображать элементы, например, «после первого параграфа отступ в 20 пикселей» или «весь текст в элементе body должен быть темно-серым и написан шрифтом Verdana».
CSS-препроцессоры
CSS-препроцессор (от англ. CSS preprocessor) — это надстройка над CSS, которая добавляет ранее недоступные возможности для CSS, с помощью новых синтаксических конструкций.
Основная задача препроцессора — это предоставление удобных синтаксических конструкций для разработчика, чтобы упростить, и тем самым, ускорить разработку и поддержу стилей в проектах. «Синтаксический сахар» — конструкции, которые не вносят ничего принципиально нового в технологию, но делают работу с ней удобнее, проще и человечнее.
CSS-препроцессоры преобразуют код, написанный с использованием препроцессорного языка, в чистый и валидный CSS-код.
Популярные CSS-препроцессоры
- Less — использует JavaScript или Node.js
- Sass (SCSS) — компилируется с помощью Ruby
- Stylus
.\@sidebar.\$main < . >.\@sidebar.\$wrapper < . >.\@sidebar.\$wrapper.color\:red
HTML-препроцессоры
По аналогии с CSS-препроцессорами аналогичные технологии для HTML с целью упростить написание кода и скоратить время
JavaScript
Простого знания библиотеки на JavaScript больше не достаточно. Необходимо понимать в каких случаях применение библиотеки действительно уместно, и уметь работать со старым добрым JavaScript, если это потребуется. Необходимо так же понимать принцип работы структур данных вроде объектов и массивов; функции, в том числе как и почему их нужно вызывать и применять; уметь работать с наследованием через прототипы; и справляться с асинхронностью.
JS-framework’и
JS-framework’и — это инструменты для построения динамических веб/мобильных/настольных приложений на языке Javascript. Как и к любым другим инструментам, разработчики прибегают к использованию js-фреймворков там, где невозможно/очень сложно/очень долго выполнять задачу обычными средствами.
Фреймворки для фронтенд-разработки
- React.js
- Vue.js
- Angular
- jQuery
- Node.js
Фреймворки для работы с данными
- Redux
- GraphQL
- Apollo
Сборщики Gulp, WebPack
Менеджеры задач Gulp и Grunt, работающие через NPM — Node Package Manager. Также полезно попробовать сборщик модулей Webpack.
Система управления версиями файлов (Git, GitHub, CVS и т. д.)
Без GitHub, в общем и целом фронт-енд разработчик не может участвовать в жизни крупного сообщества с открытым исходным кодом, которое выросло вокруг технологий фронт-енд разработки. Клонирование репозитория с целью испробовать его возможности должно стать привычным делом важно понимать как использовать ветки в совместных проектах.
Модульный принцип организации, управление зависимостями и тестовые сборки
RequireJS инструменты делают возможной разработку с использованием небольших модульных файлов JS и CSS, а затем конкатенируют и минифицируют их с помощью своего инструмента оптимизации для дальнейшего использования.
Если вышеописанный вариант не подходит по каким-либо причинам, можно использовать инструменты вроде UglifyJS или Closure Compiler, которые грамотно сжимают необходимый код, а затем конкатенируют эти сжатые файлы перед выдачей результата.
Если же код пишется на чистом CSS — то есть не используется препроцессор вроде Sass или Stylus — RequireJS также поможет организовать необходимые CSS файлы по модульному принципу. Просто необходимо использовать @import в основном файле, чтобы загрузить зависимости для разработки и затем запустить средство оптимизации RequireJS для основного файла чтобы создать готовый для использования файл.
Инструменты разработчика, встроенные в браузер
За последние несколько лет инструменты для разработчиков, встроенные в браузеры, ощутимо усовершенствовались. Если научиться ими правильно пользоваться, то они могут существенно улучшить опыт разработки. Стоит выбрать один браузер, чьи инструменты разработчика будут использоваться на постоянной основе, но не надо отказываться полностью от инструментов в других браузерах, так как в них время от времени на основе откликов разработчиков добавляются новые полезные возможности. В Dragonfly от Opera, в частности, были добавлены некоторые возможности, выделяющие её инструменты разработчика на фоне других, например: (экспериментальный) CSS- профилировщик, настраиваемые горячие клавиши, удалённая отладка без необходимости USB-подключения, а также возможность сохранять и использовать пользовательские цветовые палитры.
Командная строка
Есть несколько задач, которые необходимо выполнять через командную строку не задумываясь:
- ssh для подключения к другой машине или серверу
- scp для копирования файлов на другую машину или сервер
- ack или grep для поиска файлов в проекте по строке или шаблону
- find для обнаружения файлов, чьи названия совпадают с данным шаблоном
- git для выполнения хотя бы базовых действий вроде add, commit, status и pull
- brew для использования Homebrew для установки пакетов
- npm для установки пакетов Node
- gem для установки пакетов Ruby
Тестирование
Написания модульного, свободно сопряжённого кода состоит в том, что такой код намного легче тестировать, а с инструментами вроде Grunt, подготовка проекта со встроенными тестами вообще стала проще простого. В Grunt интегрирован QUnit, однако существует много фреймворков для тестирования, из которых можно выбрать те, что по душе.
В то время, как тестирование модульного, свободно сопряжённого кода является приятным, тестирование плохо организованного кода может быть чем-то средним между сложным и невозможным. С другой стороны, если принудить себя написать тесты, возможно, даже до того, как написан код — это поможет систематизировать свой подход и код. Это также даст возможность перестроить код с большей уверенностью в будущем.
Автоматизация процесса
Возможность с помощью Grunt настроить проект со встроенной поддержкой модульного тестирования — это один из примеров автоматизации процессов. Реальность фронт-енд-разработки такова, что разработчику приходится выполнять множество повторяющихся действий, но, как говорится: хороший разработчик — ленивый разработчик. Если какое-либо действие выполняется больше трёх раз, пора его автоматизировать.
Что такое фронтенд-разработка и с чего начать ее изучать
Когда мы открываем сайт или приложение, мы взаимодействуем с меню, разными кнопками, баннерами, плашками, всплывающими окнами и анимациями. Это называется фронтенд (или frontend), что в переводе с английского означает «внешний интерфейс».
Фронтенд-разработка — это создание внешнего интерфейса веб-сайтов и приложений. Для фронтенд-разработчика важно, чтобы пользователи с легкостью могли найти на сайте все, что им нужно. К примеру, прочитать подробности о товаре, узнать о его преимуществах, почитать отзывы, посмотреть видео и сделать покупку.
Профессия «Фронтенд-разработчик»
- Изучите востребованные JavaScript и TypeScript
- Научитесь создавать пользовательские интерфейсы сайтов и приложений
- Освойте самый популярный фреймворк JavaScript — React
- Познакомьтесь с языками веб-разработки HTML и CSS
Чем занимается фронтенд-разработчик
Прежде чем пользователи увидят сайт нового сервиса, его нужно отрисовать. Этим занимаются дизайнеры: они разрабатывают макет — черновик будущей страницы. Определяют, какие у сайта будут цвета, шрифты, визуальные элементы, а также как и где они будут располагаться.
После того как макет готов, к работе подключается фронтенд-разработчик. Фронтендер превращает этот макет в код и делает интерфейс живым, чтобы пользователи могли кликать по красивым кнопкам, заполнять формы и всячески взаимодействовать с будущей страницей.
Перечислим несколько основных задач, которыми занимается фронтенд-разработчик.
Верстка
Фронтенд-разработчик создает структуру, схему страницы с помощью языка разметки HTML (HyperText Markup Language — «язык гипертекстовой разметки»). Согласно дизайнерскому макету, программисты определяют, как различные элементы, такие как заголовки, абзацы, списки и изображения, будут располагаться на странице. Они размещают текст, изображения, кнопки и другие элементы на странице так, чтобы они легко читались и удобно располагались.
Давайте разберем подробнее, как фронтендер работает с версткой и HTML.
HTML-код состоит из разных слов, которые называются тегами. Эти слова записываются в обычный текстовый файл, после чего он сохраняется как HTML-файл, который можно открыть в браузере. Браузер читает этот код, делает его понятным для глаз и показывает страницу так, как хотел создатель. Посмотреть, как выглядит браузерная страница, можно с помощью клавиши F12.
Вот так выглядит страница с кодом одной из наших предыдущих статей:
Открыв код, мы сразу видим теги. Например, — это тег для заголовка первого уровня, а
— для абзаца текста. Теги могут быть вложены друг в друга, создавая иерархию. Внутри тегов можно вставлять текст, изображения, видео, ссылки.
Также в коде есть элементы, которые состоят из открывающего и закрывающего тегов (
.
), и в них находится контент. В нашем случае в тегах находится абзац текста.
И еще у тегов могут быть атрибуты, которые предоставляют дополнительную информацию о теге. Например, : здесь src и alt — это атрибуты.
Стилизация
Многие из элементов HTML уже имеют какое-то свое визуальное оформление: у параграфов есть отступы, ссылки в тексте выделяются, как правило, синим цветом и подчеркиваются, заголовкам устанавливаются другие значения размера шрифта. Но для создания красивых современных сайтов этого недостаточно. Какие-то стили нам просто не подходят, а какие-то элементы мы хотим стилизовать отдельно.
В этом помогает язык таблиц стилей CSS (Cascading Style Sheets — «каскадные таблицы стилей»). Благодаря CSS фронтенд-разработчик задает внешний вид элементов. Он выбирает нужные цвета, шрифты, размеры и создает стиль, чтобы интерфейс выглядел привлекательно и согласованно.
Как это происходит: сначала разработчик указывает, какие элементы на странице он хочет стилизовать. Возьмем, к примеру, стилизацию того же абзаца.
p> Тестирование - это проверка программного обеспечения, которая показывает, соответствует ли оно ожиданиям разработчиков и правильно ли работает. p>
Далее фронтендер создает правила стилей. Это как инструкции, которые говорят браузеру, как выглядеть каждому выбранному элементу. Разработчик устанавливает цвет текста, размер шрифта, отступы и многое другое. В нашем случае пусть цвет абзаца будет синим.
p color: blue; font-size: 20px; >
После этого, когда браузер загружает страницу, он читает CSS-код и применяет стили к соответствующим элементам. Так как мы указали, что весь абзац должен быть написан синим цветом, браузер окрасит его в синий.
Если разработчик захочет изменить внешний вид страницы, он просто изменит CSS-код. Так можно легко вносить изменения без необходимости менять саму HTML-структуру страницы.
Интерактивность
Интерактивность — это такое свойство страницы, которое определяет, насколько пользователям удобно взаимодействовать с ней: нажимать на кнопки, делиться в соцсетях, писать комментарии.
Сначала фронтенд-разработчик проводит мини-исследование: какие действия пользователи должны будут совершить на странице. Это могут быть клики на кнопки, заполнение форм, перемещение мышью и многое другое. Далее фронтендер создает нужные элементы — кнопки, поля ввода, ссылки.
После этого разработчик использует язык программирования JavaScript и пишет код. С помощью JavaScript-кода после нажатия на кнопку всплывает окно, а после заполнения формы (например, при оставлении комментария) данные отправляются на сервер.
Адаптивность
Фронтэнд-разработчик делает интерфейс адаптивным, чтобы он хорошо выглядел и работал на разных устройствах — компьютерах, планшетах и смартфонах.
Вот так все та же страница с недавней статьей Хекслета может выглядеть в браузере и на iPhone XR.
Оптимизация
Фронтенд-разработчик также работает над оптимизацией страницы, то есть делает так, чтобы страница загружалась быстро и работала плавно. Для этого он сначала изучает, какие элементы могут замедлить загрузку или работу страницы. Это могут быть большие изображения, сложные стили, скрипты.
После этого фронтендер уменьшает размер этих элементов с помощью специальных алгоритмов, которые сохраняют качество, но уменьшают объем файлов. Еще он настраивает кеширование — сохранение браузером некоторых файлов на компьютере пользователя. Это позволяет быстрее загружать страницу, так как некоторые данные уже есть на компьютере по умолчанию.
Также разработчик следит, чтобы некоторые элементы загружались параллельно, не блокируя друг друга. Например, если на странице есть видео, которое можно воспроизвести, скрипт для управления воспроизведением может загружаться асинхронно. Так вы увидите основной контент страницы быстрее, даже если скрипт еще не загружен полностью.
Тестирование
В конце своей работы фронтенд-разработчик проверяет, чтобы все элементы готового интерфейса работали правильно и выглядели хорошо на разных браузерах и устройствах. Вот условный чек-лист, которым руководствуется фронтендер:
- Текст, изображения, кнопки и другие элементы расположены корректно и выглядят согласно дизайну, а цвета и шрифты соответствуют стилю.
- Страница отображается корректно на устройствах и экранах. Контент правильно подстраивается под разные размеры экранов.
- Интерактивные элементы реагируют на действия пользователя, например, при кликах и наведении мыши.
- Все ссылки работают и ведут пользователя на нужные страницы, а меню и другие элементы навигации функционируют корректно.
- Анимации работают плавно и без задержек.
- Пользователи могут вводить данные и отправлять их на сервер, а данные валидируются на корректность.
- Страница загружается и отображается для пользователей без задержек.
Читайте также: Мой долгий путь во фронтенд-разработку: через строительный вуз, юриспруденцию и усердную учебу на Хекслете
Чем задачи фронтендера отличаются от задач верстальщика и других разработчиков
Разработчик интерфейса всегда работает в команде и связан сразу с несколькими специалистами. Среди них — дизайнеры, верстальщики, тестировщики и другие разработчики.
Как мы уже говорили ранее, дизайнер создает макет, который затем превратится в сайт. Верстальщик делает разметку страницы, по которой фронтендер позже будет ориентироваться и расставлять элементы в нужном порядке. Тестировщик смотрит, чтобы все работало исправно — так, как заявлено в плане. А тимлид координирует работу фронтендера, оценивает код и дает рекомендации для проработки продукта.
Многие путают работу верстальщика и фронтендера — они действительно схожи. Но в их работе есть большая разница.
Основная задача верстальщика — создание визуального вида веб-страницы. Верстальщик структурирует и стилизует страницу с помощью HTML и CSS, уделяет внимание расположению текста, цветам, шрифтам. Фронтенд-разработчик, как и верстальщик, учитывает дизайн, но также занимается функциональностью страницы. Создает интерактивные элементы, анимации, валидацию форм и динамическое обновление данных без перезагрузки страницы.
Также фронтенд-разработчики работают с бэкенд-разработчиками. Как мы уже выяснили, фронтенд — это все, с чем можно повзаимодействовать, понажимать, поскроллить. А бэкенд (backend — «внутренний интерфейс») — это внутренняя часть продукта и все, что находится «под капотом» — команды для сервера.
Фронтенд-разработчики получают от бэкендеров API — интерфейс программирования приложений. Он определяет, как данные будут обмениваться между клиентской и серверной частями. Фронтенд-разработчики используют этот API для получения и отправки данных.
Какие навыки нужны фронтенд-разработчику
Чтобы фронтенд-разработчику создавать красивые, интерактивные и функциональные веб-интерфейсы, ему нужно:
- Знание HTML и CSS — для создания и стилизации элементов веб-страницы.
- Знание языка JavaScript — для добавления интерактивности, анимаций и обработки событий.
- Знание библиотек и фреймворков и умение с ними работать. Опыт работы с популярными библиотеками и фреймворками, такими как React, Vue или Angular, упрощает создание сложных интерфейсов и повышает эффективность разработки.
- Уметь работать с версткой адаптивного дизайна, чтобы веб-страницы правильно отображались на разных устройствах.
- Понимание основных принципов дизайна, чтобы создавать эстетически приятные интерфейсы.
- Умение работать с инструментами разработки, вроде редакторов кода, системы контроля версий.
- Понимание SEO — для создания веб-страниц, которые легко находятся и индексируются поисковыми системами.
- Умение работать с API, чтобы работать с внешними источниками данных и интегрировать разнообразные функциональности.
Сколько зарабатывают frontend-разработчики и как развиваться в профессии
В середине августа 2023 года на рекрутинговом сервисе hh.ru было опубликовано примерно 3350 вакансий Фронтенд разработчиков в России. Зарплата junior frontend-разработчиков начинается от 55 тыс. рублей и достигает 100 тыс. рублей. Middle разработчики получают от 115 до 310 тыс. рублей. Senior фронтенд-разработчики могут претендовать на зарплату от 300 до 610 тыс. рублей.
По данным исследования сервиса «Хабр Карьеры», медианная зарплата фронтенд-разработчиков в первом полугодии 2023 года составила 180 000 рублей.
Можно двигаться вертикально и пройти путь от джуниор-разработчика до позиции мидла, затем до сеньора, а после этого вырасти до тимлида. На первых трех уровнях вы в основном будете работать с кодом и вышеупомянутыми фреймворками, а со временем сможете строить архитектуру интерфейсов — это более сложная задача.
На позиции тимлида вы станете скорее техническим менеджером, который будет управлять проектом и командой, наставлять менее опытных коллег и общаться с клиентом.
Есть вариант развиваться горизонтально — начать с верстки и перейти в front end или из фронтендера стать бэкендером. Либо же работать на фулстеке — это когда вы совмещаете обязанности фронтенд- и бэкенд-специалистов и сразу комплексно разрабатываете сайт или приложение.
Как стать frontend-разработчиком
Начните с изучения основ — HTML и CSS, затем JavaScript. Также познакомьтесь с фреймворками. Самые распространенные фреймворки и доступные для начинающих сейчас — это React, Angular и Vue.js.
Кстати, помимо знания языков программирования, не лишним будет уверенное знание английского, а особенно технического. На нем каждый день публикуют тысячи полезных материалов. С таким навыком специалист сможет в оригинале читать актуальные статьи, техническую документацию и рекомендации по разработке со всего мира. Знание английского также позволит работать в командах с иностранными разработчиками.
Вот несколько хороших книг и ресурсов для погружения в фронтенд-разработку:
- « Грокаем алгоритмы » Адитьи Бхаргавы — классическая книга для начинающих разработчиков, которые хотят понять синтаксис и алгоритмы.
- « JavaScript. Подробное руководство » Дэвида Макфарланда — книга поможет вам понять основы JavaScript.
- « Секреты CSS. Идеальные решения ежедневных задач » Леа Веру — книга-сборник интересных CSS-задач.
- MDN Web Docs — официальный сайт Mozilla Developer Network, который предоставляет подробные и понятные объяснения HTML, CSS и JavaScript.
- Бесплатный курс Хекслета «Основы JavaScript» — поможет изучить основы языка и потренировать свои навыки в онлайн-тренажере.
Профессия «Фронтенд-разработчик»
- Изучите востребованные JavaScript и TypeScript
- Научитесь создавать пользовательские интерфейсы сайтов и приложений
- Освойте самый популярный фреймворк JavaScript — React
- Познакомьтесь с языками веб-разработки HTML и CSS
Frontend
Frontend (фронтенд) представляет собой публичную часть сайта (веб-приложения), которая обеспечивает прямое взаимодействие пользователя с веб-ресурсом. В понятие frontend входит:
- вывод на сайте интерфейса пользователя;
- выполнение функциональных задач;
- обработка определенных запросов посетителей и т. д.
Фронтенд — это буквально все, что видит посетитель сайта, открывая любую его страницу.
Разработка сайтов для бизнеса
Что такое веб-приложение
Понятие «веб-приложение» стоит рассматривать как клиент-серверное программное обеспечение, где клиентом выступает браузер, а сервером — веб-сервер, на котором находится сайт.
Логика веб-приложений распределяется между клиентом и сервером — вся информация сайта хранится на сервере, а обмен данными между клиентом и сервером осуществляется через интернет.
Web-приложение — видимая для посетителя часть сайта, на которой можно выполнять определенные действия при каждом подключении к сети и открытии веб-ресурса через интернет-браузер.
Что такое фронтенд-разработка
Frontend-разработка подразумевает работу программиста над созданием видимой части веб-ресурса, с которой посетитель будет контактировать. В frontend-разработку входит создание функционала сайта, который может выполняться на стороне клиента.
Frontend-разработчик трудится над тем, чтобы на сайте работали все кнопки, иконки, формы связи и подписки, правильно отображались тексты и графические элементы, чтобы все они «стояли на своих местах» и выполняли те задачи, которые перед ними были поставлены (например, чтобы при клиенте по кнопке «заказать» открывалась форма для оформления покупки, а при нажатии на кнопку «play» включалось видео и т. д.).
Чтобы конечный продукт frontend-разработчика был качественный, востребованный среди пользователей и отвечал поставленным перед ним требованиям, необходимо обеспечить грамотное взаимодействие этого разработчика со всеми остальными специалистами, которые работают над задачей: веб-дизайнерами, маркетологами, SMM-щиками, аналитиками и т. д.
С какими языками работает фронтенд-разработчик
Фронтенд-разработчик работает со следующими компонентами:
- Фреймворки (React.js, AngularJS, Vue.js, Ember.js и т. д.). Платформы, дающие фронтенд-разработчику основу для создания веб-приложений. В них присутствуют уже определенные и реализованные функции с классами. Также в фреймворках можно добавлять свой код к уже предложенному.
- Cascading Style Sheets (CSS). Язык стилизации внешнего вида веб-страницы. При помощи CSS клиент (браузер) «понимает», каким именно образом нужно отображать графические элементы на сайте. При помощи CSS задаются цвета, шрифты, расположения блоков и т. д. CSS-код помогает адаптировать веб-приложение, чтобы оно одинаково отображалось на разных устройствах.
- HyperText Markup Language (HTML). Язык разметки всех элементов страницы, позволяющий также прописать особенности их взаимодействия друг с другом.
- JavaScript. Язык, способный «оживить» веб-страницы. Цели создания таких скриптов — отклики на действия посетителей, обработка перемещения курсора мыши, нажатий на клавиши, отправленных запросов, загрузки данных без перезагрузки самой страницы и т. д.
- Сопутствующие системы. Понимание работы инструментов для контроля версий (GitHub, Git, CVS и т. д.), минимальное владение графическими редакторами по типу Photoshop, Illustrator, знание английского языка.
Кто такой frontend-разработчик?
Эта профессия — как кажется, один из самых простых входов в IT, хотя если копнуть немного глубже базовых знаний верстки, оказывается, что она едва ли не сложнее всех остальных. Вместе с ментором курса «Frontend-разработчик» Алексеем Видякиным сравниваем разработку сайта с созданием автомобиля, раскрываем нюансы специальности и ищем подводные камни.
Кто такой frontend-разработчик
Frontend-разработчик (frontend developer) — это специалист, который отвечает за создание пользовательского интерфейса сайта, приложения или ПО. Разберемся, что такое фротенд и бэкенд в веб-разработке. Backend — это то, что находится на веб-сервере, «под капотом». Фронтендом сайта называют все, что пользователь видит в браузере и с чем взаимодействует, когда вводит данные и получает обратную связь.
Освойте профессию «Frontend-разработчик»
Frontend-разработчик
Научитесь создавать удобные и эффектные сайты, сервисы и приложения, которые нужны всем. Сегодня профессия на пике актуальности: в России 9000+ вакансий, где требуется знание JavaScript.
Профессия / 9 месяцев
Frontend-разработчик
Создавайте интерфейсы сервисов, которыми пользуются все
2 400 ₽/мес 4 000 ₽/мес
Разработку сайта можно сравнить с созданием новой модели автомобиля. В этой аналогии инженеры, работающие над характеристиками шасси, двигателя и трансмиссии, — это backend-разработчики. А дизайнеры и инженеры, отвечающие за панель приборов, эргономику салона и удобство управления автомобилем, — это фронтендеры. Поэтому frontend-разработчику нужны как дизайнерские, так и инженерные навыки. Узнайте больше о профессии в нашем карьерном гиде. Ссылка в конце статьи.
Где работает и какие задачи решает frontend-разработчик
- IT-департаменты компаний. Ритейлеры и маркетплейсы, сотовые операторы и банки, соцсети и стриминговые платформы совершенствуют свои сервисы. Крупнейшие из них сами задают тренды во frontend-разработке. Например фреймворк React создал программист из Facebook. Работать можно как внутри компании, так и в агентстве, которое специализируется на аутсорс-разработке.
- Разработчики корпоративного софта. Тут нужно будет создавать сервисы управления проектами, CRM и другие веб-приложения для бизнеса. Такое ПО часто имеет сложные интерфейсы и нуждается в регулярной поддержке.
- Государственные организации. Такие сервисы, как «Госуслуги», «Налог.ру», городские информационные порталы постоянно растут и совершенствуются, вовлекая в свою работу в том числе этих специалистов.
Станьте Frontend-разработчиком
и создавайте интерфейсы сервисов, которыми пользуются все
Чем задачи фронтендера отличаются от задач верстальщика
Базовые инструменты для создания страницы сайта — язык разметки веб-страниц HTML, каскадные таблицы стилей CSS и язык программирования JavaScript. На HTML пишут скелет страницы, благодаря CSS она приобретает привлекательный внешний вид.
Когда странице задана структура и для нее описаны стили — она сверстана. Этими инструментами владеет верстальщик. В его обязанности иногда входят несложные операции с JavaScript, например подключение плагинов и скриптов, отвечающих за оживление статичных страниц.
На небольших проектах задачи верстальщика и frontend-разработчика нередко выполняет один человек.
Читайте также В чем разница между frontend- и backend-разработкой? Объясняем на мемах
По мере усложнения функционала сайтов и приложений все большая часть разметки страниц и их содержимого генерируется динамически, то есть создается с помощью JavaScript, и наполняется данными, полученными с сервера. Эти задачи можно продолжить решать на чистом JavaScript или использовать библиотеки, но такой сайт будет недостаточно быстрым, а его разработчики скоро начнут стонать из-за возрастания объемов кода и непомерного усложнения его структуры.
Для создания большого и сложного веб-приложения требуются более узкие специалисты и мощные инструменты. На таком проекте задачи верстальщика и frontend-разработчика разделяются. Фронтендер занимается исключительно программированием, причем с использованием фреймворка, подходящего для решения поставленной задачи.
Сколько зарабатывают frontend-разработчики
В марте 2023 года зарплаты frontend-разработчиков варьируются от 40 000 рублей для Junior-специалиста до 380 000 для тимлида. При этом средняя зарплата начинающих специалистов — около 80 000 руб. Средняя зарплата фронтенд-разработчика – 155 тысяч рублей.
Как стать frontend-разработчиком
Чему учиться?
Программисты со стажем немного лукавят, когда говорят о низком пороге входа в профессию frontend-разработчика. Под этим обычно подразумевается легкость изучения базовых технологий, связанных с версткой (HTML и CSS), и начальных навыков оживления веб-страниц с помощью плагинов и библиотек. Но в 2023 году это лишь малая часть того, что должен знать и уметь фронтендер.
«В 2017 году я устроился на свою первую работу, зная лишь HTML, CSS, немного JavaScript и JQuery, — рассказывает Алексей Видякин. — Сегодня, в 2023 году, требования очень выросли, поскольку выросла конкуренция. Базовыми знаниями верстки уже никого не удивишь».
Вот примерный список требований к джуниор-специалисту в 2023 году:
- Знать HTML и CSS. Под этим подразумеваются навыки кроссбраузерной и адаптивной верстки, знание популярных CSS-фреймворков, препроцессоров и HTML-шаблонизаторов.
- Знать JavaScript, в частности стандарт Ecmascript 6 — спецификацию 2015 года, принесшую языку новые элементы синтаксиса и новый уровень производительности.
- Иметь базовые навыки работы в консоли и пользования пакетным менеджером NPM, позволяющим быстро и удобно загружать JavaScript-библиотеки и приложения.
- Уметь пользоваться системой контроля версий, например Git. Навыки работы с Git лучше всего развиваются в процессе командной работы, поэтому от новичка никто не ждет совершенства в работе с платформой. Достаточно понимать, о чем вообще речь, и знать несколько базовых команд.
- Уметь работать со сборщиком проектов (это небольшой код, определяющий последовательность действий при автоматическом запуске приложения из командной строки). Тут важно понимание самой идеи инструмента и базовые навыки пользования. Сборщиков несколько, самый популярный из них — gulp.js.
- Базово знать один из современных фреймворков: React, Angular или Vue.js. С их помощью разработчик может минимизировать количество обращений к DOM (Document Object Model — объектная модель документа) и организовать мгновенный обмен данными с сервером через API. Вместо того чтобы по каждому клику перезагружать страницу целиком, фреймворк управляет состоянием ее отдельных компонентов, обеспечивая пользователю мгновенный отклик приложения. Подразумевается, что если человек сумел освоить один из них, то сможет достаточно быстро разобраться с другим, если возникнет необходимость. Есть довольно много вакансий, где требуется какой-то конкретный фреймворк.
- Знать английский. Не факт, что от соискателя сразу потребуется обсуждать что-то со штаб-квартирой Facebook, но реакции «Тут нет документации на русском, поэтому я не смогу разобраться» тоже уже не принимаются.
Читайте также Backend-разработчик: кто это такой и чем занимается
Где начать работать?
Существует три основных варианта трудоустройства: фриланс, студия веб-разработки и работа на стороне заказчика.
В качестве оптимального места первой работы Алексей Видякин называет студию веб-разработки, поскольку именно среди узких специалистов и разнообразных задач проще всего расти от простого к сложному. Но при этом поначалу нужно быть готовым к большому количеству рутины.
«На позиции trainee (стажера) я выполнял ту работу, за которую не хотели браться более опытные сотрудники, — вспоминает Алексей. — В основном это были правки от заказчика, то есть дополнения на сайте, которые нужно просто внести по определенному шаблону, ничего не поломав при этом. Дополнительная ценность такой работы в том, что ты начинаешь понимать, как устроены реальные проекты именно в вашей студии».
Начиная работать с нуля на фрилансе, легко застрять на выполнении низкооплачиваемых примитивных задач. При этом рядом с вами не будет руководителя, заинтересованного в вашем профессиональном росте. А вот для опытного frontend-разработчика фриланс, особенно на международных биржах, может открыть много возможностей.
Работа на стороне заказчика может стать отличным стартом, но стоит искать компанию, которая будет расти вместе со специалистами. IT-отделы в крупных компаниях часто создают для быстрого решения сложных задач и нанимают для этого дорогих и эффективных специалистов.
С чего начать
«Для многих, и для меня в том числе, frontend был хобби, прежде чем стать профессией. Создавая с нуля свой первый, далеко не идеальный сайт, вы сможете понять, увлекает ли вас это занятие. Но на первой работе вам, особенно поначалу, потребуется больше терпения и внимательности, чем креативности, — рассуждает Алексей. — Чтобы не перегореть на этом этапе и вырасти до действительно креативных и высокооплачиваемых задач, важно иметь изначальный интерес к веб-разработке».
Лучший способ понять, интересна ли вам frontend-разработка, — взять и попробовать. Вот несколько полезных ссылок, с которых можно начать:
Бесплатные курсы:
- HTML and CSS Tutorial for 2021
- JavaScript Tutorial for Beginners
- 15 Vanilla Javascript Projects
- HTML, CSS, and Javascript in 30 minutes
Сообщества программистов:
- Stack Overflow
- Habr Q&A (бывший toster.ru)
Книги:
- «Новая большая книга CSS», Д. Макфарланд
- «Чистый код», Р. Мартин
- «Профессиональный TypeScript», Б. Чёрный
- «Изучаем JavaScript. Руководство по созданию современных веб-сайтов», Э. Браун
Начать учиться можно и без самостоятельной подготовки. На курсе SkillFactory Frontend-разработчик вы пройдете путь от самых основ до создания сложных продуктов. Сначала вы научитесь создавать веб-сайты, затем — разрабатывать интерактивные веб-сайты и приложения на JavaScript и HTML, писать сложные компоненты на React.
Практика по Frontend-разработке
В ходе курса мы даем вам правила и теорию, а на тренажерах вы сами отрабатываете практические навыки. Заключительный трек курса — карьерный. В нем специалисты Карьерного центра помогают вам составить резюме и подготовиться к собеседованию в компанию мечты.