Иерархическая модель – представление – контроллер - Hierarchical model–view–controller

Структура приложения с PAC.

Иерархическая модель – представление – контроллер (HMVC) это программное обеспечение архитектурный образец, вариант модель – представление – контроллер (MVC) похож на презентация – абстракция – контроль (PAC), который был опубликован в 2000 году в статье[1] в JavaWorld Журнал, авторы, видимо, не подозревают[2] PAC, который был опубликован 13 годами ранее.

Контроллер имеет некоторый надзор, поскольку он сначала выбирает модель, а затем представление, реализуя механизм утверждения контроллером. Модель предотвращает прямой доступ представления к источнику данных.

Пример

Самым большим практическим преимуществом использования архитектуры HMVC является «виджетизация» структур контента.[3] Примером могут быть комментарии, рейтинги, отображение RSS-канала Twitter или блога или отображение содержимого корзины покупок для веб-сайта электронной коммерции. По сути, это фрагмент контента, который необходимо отображать на нескольких страницах и, возможно, даже в разных местах, в зависимости от контекста основного HTTP-запроса.

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

HMVC, или, в частности, возможность отправлять подзапросы контроллеру для выполнения этих обязанностей, направлена ​​на решение этой проблемы. Структура имитирует структуру традиционного MVC. Например, если нужно загрузить некоторые данные о комментариях и отобразить их в формате HTML, нужно отправить запрос в Контроллер комментариев с некоторыми параметрами. Затем запрос взаимодействует с моделью, выбирает представление, в котором отображается контент. Отличие от традиционного MVC заключается в том, что комментарии отображаются не на полностью отдельной странице, а в строке под статьей, которую просматривает пользователь. В связи с этим HMVC стремится к увеличению кода модульность, помощь в повторном использовании и лучшее разделение проблем.

Смотрите также

Рекомендации

  1. ^ Кай, Джейсон; Капила, Ранджит; Пал, Гаурав (21 июля 2000 г.). «HMVC: многоуровневый шаблон для разработки сильных клиентских уровней». JavaWorld. Получено 2020-07-18.
  2. ^ «ТП» (8 сентября 2000 г.). "Является ли HMVC PAC?". Письма в редакцию. JavaWorld. Архивировано из оригинал 19 марта 2006 г.
  3. ^ Вэнс Лукас (апрель 2011 г.). "почему узор HMVC?". Переполнение стека. Получено 2013-10-15.