Frontend-разработка

Присоединяйтесь к нашей программе обучения

Задание 4. Практика JavaScript.

1-2 месяца

Это последнее самостоятельное задание перед ревью. Чат для отчетов остаётся прежним — из 3-его задания.

Описание задания

Задание заключается в написании плагина для jQuery, который бы реализовывал функционал «бегунка» (также называемого слайдером) — специальный контрол, который позволяет перетягиванием задавать какое-то числовое (будет круто, если в реализации можно сделать не только числовое) значение.

Этот элемент уже использовался во втором задании, дизайн можно взять оттуда.

Перед началом практического задания рекомендуем познакомиться сстандартами разработки (bestpractices) по которым, на 5м задании, будет проводится код-ревью ваших проектов. Имеет смысл делать сразу по этим стандартам, чтобы ревью прошло быстрее. Ссылка на стандарты продублирована сюда из 5го задания.

Требования:

  • Плагин должен иметь удобное API для подключения его к элементам на странице и соответствовать best practices по созданию плагинов для jQuery.

  • Плагин должен уметь работать независимо, если подключен несколько раз на странице, не должен ломать стили остальных элементов на странице.

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

    • размер шага - он может быть ЛЮБЫМ ВАЛИДНЫМ, подстраивать max или min значения слайдера под размер шага при этом не нужно, как и наоборот, не нужно подстраивать размер шага под max или min значения, Пример невалидных значений: При min 0, а max 10, шаг не может быть 11.

    • вертикальный/горизонтальный вид,

    • одиночное значение или интервал,

    • возможность на лету изменить значение "снаружи" javascript-ом,

    • возможность включать/отключать элемент над бегунком, который показывает значение и который ползает за мышкой (при выключении просто кругляш сам только на слайдера, при включении над кругляшом элемент с цифрой).

    • шкала значений - элемент, который отображает диапазон значений, в пределах которого можно двигать ползунок. Минимальное значение шкалы = значению min слайдера, максимальное = значению max слайдера. Шкала должна быть интерактивной. Т.е. при клике на значение шкалы, ползунок должен перемещаться на позицию этого значения.

    • прогресс бар - элемент от min до значения первого ползунка, при одиночном значении, либо, от значения первого ползунка до значения второго ползунка при интервале. Узнать как выглядит прогресс бар(разноцветные полоски)

    • отзывчивость - слайдер должен тянуться/сужаться, по ширине, вместе с растягиванием/сужением своего контейнера.

    • Работа на тач устройствах - слайдер должен корректно работать на тач устройствах

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

  • Панель должна быть синхронизирована со слайдером.

  • Для манипуляций числовыми значениями нужно использовать input с типом number или text.

  • Весь код должен быть на Github в вашем публичном репозитории, результатом задачи будет как раз этот репозиторий.

  • Требования к ежедневности коммитов и их названиям остаются, как во втором задании: коммиты минимум раз в день, когда вы хоть что-то сделали, у всех элементов должны быть осознанные названия.

  • Обязательно написание кода на TypeScript. Мы используем этот язык в разработке, он помогает держать сложность больших проектов под контролем, а также выручает при проектировании. Cтарайтесь настроить tsconfig максимально строгим образом. Код тестов желательно тоже писать на TypeScript, но это нестрого обязательно.

  • Использовать ‘any’ разрешается только в одном случае. Когда у вас совершенно никак не получается затипизировать без использования ‘any’ и вы испробовали все возможные варианты. Также вам ОБЯЗАТЕЛЬНО нужно будет написать подробный комментарий, почему вы не смогли обойтись без использования ‘any’.

  • У вашего приложения должны быть четко разделенные слои приложения:

  • Нужно сделать отдельный слой управления данными (Model), который будет содержать бизнес-логику приложения и не производить никаких расчетов, которые нужны для отображения.

  • Отдельный слой для управления отображением (View) — здесь нельзя проводить никаких расчетов, относящихся к бизнес-логике. Слой должен содержать логику, связанную с отображением (например, для изменения положения ползунка слайдера на экране), а также реагировать на взаимодействие пользователя с приложением. Каждый компонент слайдера (бегунки, шкала и т. д.) должен быть представлен отдельным классом. Благодаря такой декомпозиции View, функционал будет четко разделен между subViews, а вы научитесь решать проблемы взаимодействия в рамках многоуровневой структуры.

  • Отдельный слой для обновления модели и отображения (Controller или Presenter). Это - единственный слой среди трех, который может иметь зависимость от других слоев. Он будет:

    • реагировать на сообщения от отображения о действиях пользователей и обновлять модель;

    • реагировать на сообщения об обновлении модели и обновлять отображение.

  • На выходе должно получиться подобие MVP-архитектуры с Passive View. Обязательно прочитайте про MVC архитектуру, про то, зачем она нужна, и какие у нее есть ответвления. Также изучите, как можно писать MVC-приложения на JavaScript. Вот несколько полезных источников:

    • https://addyosmani.com/blog/understanding-mvc-and-mvp-for-javascript-and-backbone-developers/ — описание MVC и MVP архитектур и различий между ними;

    • https://habrahabr.ru/post/321050/ — подробный разбор MVC, часть 1;

    • https://habr.com/ru/post/322700/ — подробный разбор MVC, часть 2;

    • https://habrahabr.ru/post/276593/ — основы архетектуры, статья довольно сложная для новичка, нормально, если вы её в первый раз не очень глубоко поймёте, а потом под конец 4-го задания ещё раз вернётесь;

    • Мы ожидаем, что это требование создаст больше всего проблем для вас и вызовет больше всего вопросов, зато для вас это будет самым ценным опытом — разобраться в простейших паттернах проектирования и попробовать создать что-то свое небольшое с нуля, используя такие паттерны. По возникшим вопросам (правильно сформулированные, например, по рекомендациям данным выше) вам всегда могут помочь в общих чатах нашей программы. Так что смело задавайте вопросы, экспериментируйте и готовьтесь к тотальному переписыванию кода минимум пару раз :)

  • Архитектура приложения должна быть задокументирована:

    • В README проекта нужно добавить описание вашей архитектуры.

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

    • Помимо этого, вы должны составить UML-диаграмму своего приложения, которую тоже нужно добавить в README. Программа для составления диаграммы:https://www.draw.io/

    • Приложение должно быть покрыто тестами:

      • Самые основы можно почитать в главе у Кантора:https://learn.javascript.ru/testing. («В этой главе мы разберём основы автоматического тестирования. Оно будет применяться далее в задачах, и вообще, входит в “образовательный минимум” программиста.»).

      • Сами тесты обязательны к написанию, должны находиться так же в репозитории, команда запуска тестов должна быть описана в README, запуск тестов после клонирования должен быть максимально простым (в идеале выполнения одной команды `npm i && npm test` должно быть достаточно), тестами должны быть покрыты все слои вашего приложения.

      • TDD (которое в том числе немного описано у Кантора) — это когда сначала пишутся тесты, а после уже сами модули и методы.

      • Это необязательное условие, особенно допустимо его нарушить для первой версии вашей программы. Желательно потом после создания каркаса попробовать некоторую функциональность добавить пару раз с использованием техники TDD (это как раз про то, что сначала должны быть тесты, потом сам код), это поможет вам лучше почувствовать методику.

    • Желательно попробовать какие-нибудь новые молодежные фичи: все на ваш выбор и все необязательно. Будет круто, если сможете написать кастомные правила для линтера или небольшой сервачок, например. Но ни в коем случае не фреймворки (Angular, Ember, etc) и не React, вам нужно самим проработать MVC-архитектуру, а указанные решения навязывают сверху что и как делить в приложении.

    • Проект можно сразу реализовывать с учетом наших СТАНДАРТОВ разработки. Имеено на соответствие этим стандартам будет проводиться ревью проекта. Ссылка на стандарты или best practices.

Задание вам даст

  • Базовые навыки проектирования (ООП, вариации MVC-архитектуры, разделение ответственности).

  • Навыки по созданию удобных библиотек с удобным API (интерфейсом использования для других разработчиков).

  • Навыки разделения конфигурирования и бизнес-логики.

  • Умение документировать свой продукт (описывать заложенную архитектуру, визуализировать её через UML-диаграммы).

  • Навыки автоматического unit-тестирования (включая TDD).

Дополнительные материалы:

менеджер программы обучения

По любым вопросам по программе обучения пишите Светлане в Telegram