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

1. HTML и CSS

HTML и CSS  —  это основа любого веб-приложения, азы фронтенд-разработки. Хорошо то, что HTML и CSS просто освоить. На это уйдет максимум несколько недель. Изучив HTML и CSS, вы уже сможете создавать базовые статические сайты.

В процессе освоения HTML и CSS, не забудьте уделить время пунктам, приведенным ниже.

DOM

DOM (от англ. Document Object Model  —  объектная модель документа)  —  это объектно-ориентированное представление веб-страницы. Важно понимать, почему каждый объект в DOM ведет себя именно так.

Манипуляции с DOM

Когда вы получите базовое представление о структуре DOM в HTML, изучите, как каждый элемент взаимодействует с другим и как это контролировать.

Семантика HTML

Семантика HTML  —  это то, что часто игнорируют многие разработчики, переходящие во фронтенд. Ее понимание играет важную роль в улучшении общей структуры, SEO и доступности вашего сайта.

Селекторы CSS

Убедитесь, что вы знаете все селекторы CSS. Тогда оформление веб-страницы станет для вас проще простого.

2. JavaScript

Когда приходит время создавать веб-сайты со сложным дизайном и функциями, одними HTML и CSS не обойтись. Это под силу только JavaScript. Он используется, чтобы сделать взаимодействие с пользователем динамичным. Все всплывающие окна, крутые переходы, анимация прокрутки и другие привлекающие внимание элементы современных сайтов создаются с помощью JavaScript. Он тоже довольно прост в изучении, особенно если вы знаете английский язык.

3. Фреймворки JavaScript

Существует много фреймворков JavaScript, даже слишком много. Среди них EmberJS, React JS, Angular JS и др. Эти фреймворки содержат шаблон или структуру кода для написания чистого кода или использования стандартных функций. Вы можете использовать этот инструмент для разработки сложных веб-приложений, особенно SPA. А раньше разработчики реализовывали логику внешнего интерфейса, очень полагаясь на Vanilla JS и jQuery.

4. Тестирование и отладка

Тестирование и отладка очень важны для любой разработки программного обеспечения, а не только для фронтенда. Каждое приложение должно быть тщательно проверено. А когда появляется сообщение об ошибке, лучше не откладывая исправить ее. Как разработчику вам нужно развивать навык написания различных тестовых сценариев для вашего веб-приложения. Или даже использовать технику разработки программного обеспечения через тестирование TDD (англ. test-driven development).

5. Отзывчивый и мобильный дизайн

Отзывчивый веб-дизайн позволяет создавать веб-страницы, которые хорошо выглядят на всех устройствах: компьютерах, ноутбуках, планшетах и смартфонах. Для автоматического изменения размера, скрытия, сжатия или увеличения веб-сайта используют HTML и CSS.

6. Кроссбраузерная разработка

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

7. Навыки решения проблем

Навыки решения проблем и логическое мышление необходимы каждому разработчику. Они нужны для написания кода, выбора шаблона, структурирования тысяч строк кода, исправления ошибок после разработки и т. д. А про терпение я вообще молчу.

8. Анализ производительности

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

Для хорошего пользовательского опыта чрезвычайно важно следить за любым веб-приложением. Каждый наш код должен быть масштабируемым, и его нужно проверять дважды. В браузерах есть инструменты для анализа производительности. Они позволяют обнаруживать неиспользуемый код, код с низкой производительностью, код, съедающий память(приводит к утечке памяти) и код, который просто не стоит использовать.

9. SEO

Поисковая оптимизация помогает привлечь трафик на ваш сайт. Она затрагивает многие аспекты: начиная с вашего домена, URL-адреса и заканчивая структурой вашего контента и тем, как он отображается на других сайтах и платформах. В Интернете есть инструкции, которые помогут сделать так, чтобы ваш веб-сайт или приложение находились в первых строчках результатов поиска.

10. Пользовательский опыт

Фронтенд-разработчик несет ответственность за то, как пользователи воспримут дизайн и какой опыт они получат. Чтобы стать профессионалом, вам необходимо понимать продукт, знать кто и как его использует. Также нужно проводить много исследований и экспериментов, чтобы получить максимальный результат. Чем лучше ваши навыки в этой области, тем более ценным специалистом для компании вы будете.

Заключение

Вы не сможете овладеть всеми этими навыками за одну ночь. Но если постоянно уделять им внимание и осознанно практиковать, то вопрос «А хороший ли я разработчик?» отпадёт сам собой.

Читайте также:

Читайте нас в Telegram, VK и Яндекс.Дзен


Перевод статьи Harsha Vardhan: Are You A Good Front End Engineer?

Предыдущая статьяИнтересные подробности об объектах JavaScript
Следующая статьяТоп-5 языков программирования для начинающих