Я создаю большое приложение javascript и решил использовать дизайн архитектуры масштабируемого приложения Николаса Закаса:
http://developer.yahoo.com/yui/theater/video.php?v=zakas-architecture
Согласно его системе, модули инкапсулированы и не знают друг о друге ... Однако в моем проекте я встречал много случаев, когда казалось необходимым, чтобы модули знали друг о друге, потому что они по сути своей , отдельные части большего целого.
Например .. У меня есть три модуля: Upload, Window и Manager.
При нажатии на параметр загрузки открывается всплывающее окно с формой загрузки. Также ссылка есть на окно «Менеджер».
При нажатии на ссылку менеджера обновляется всплывающее окно для отображения инструментов администратора ...
...
Для меня это было наиболее разумно (псевдокод):
upload module:
upload option click --> sandbox.notification('need pop up window', [...html markup for form...])
manager module:
manager link click --> sandbox.notification('need pop up window', [...html markup for admin tools...])
window module:
sandbox.listen('need pop up window') --> calls createPopUpWindow( passed in html markup )
... Однако это идет вразрез с философией, поскольку модули загрузки и управления специально «запрашивают» оконный модуль на выполнение каких-либо действий, поэтому они знают об этом ...
Итак, единственный другой способ, которым я могу придумать, это сделать:
upload module:
upload option click --> sandbox.notification('upload option clicked', [...html markup for form...])
manager module:
manager link click --> sandbox.notification('manager link clicked', [...html markup for admin tools...])
window module:
sandbox.listen('upload option clicked') --> calls createPopUpWindow( passed in html markup )
sandbox.listen('manager link clicked') --> calls createPopUpWindow( passed in html markup )
.. Но это кажется гораздо менее интуитивным, и, честно говоря, я думаю, что это делает мой код намного менее понятным, потому что, глядя на уведомление модуля загрузки «нажата опция загрузки», я не могу сказать, что это должно делать. случается, когда на него нажимают ... Мне нужно искать все остальные мои файлы для модулей, которые его слушают ..... Что, я думаю, можно рассматривать как преимущество, потому что несколько модулей могут захотеть ответить на опцию загрузки ', где, поскольку' нужное всплывающее окно 'может быть явно адресовано только одним модулем.
Но при таком подходе мне становится все меньше смысла, когда мой модуль загрузки передает разметку html, относящуюся к всплывающему окну, о котором он не знает, и он начинает выглядеть как окно модуль должен отвечать за генерацию этой разметки - но большая часть разметки зависит от «загрузки», и у разметки есть прослушиватели событий, связанные с функциями в модуле загрузки - так что наличие этого в оконном модуле не действительно логично ... так что это начинает сбивать с толку относительно того, как лучше всего структурировать все это.
У меня также есть другая ситуация, которая еще более проблематична. Два модуля: Track и Container. Контейнер имеет много дорожек, и первоначально у меня просто были функции дорожек внутри модуля контейнера - но поскольку длина кода в модуле начала расти, я решил разделить их на свои собственные модули для чистого кода ... В любом случае, поскольку контейнеру необходимо знать о его дорожках и иметь возможность ссылаться на них внутри, единственный способ, которым я мог это настроить, был сделать:
containerObject = function(name) {
this.name = name;
this.video_track = {'name': 'video', 'markup': sandbox.notification('create-track', 'video')}
this.audio_track = {'name': 'audio_1', 'markup': sandbox.notification('create-track', 'audio')}
....etc....
};
Таким образом, модуль Track выполняет sandbox.listen ('create-track') и указывает на функцию, которая возвращает новый объект track данного типа ..... Возможно, просто не стоит иметь track будь его собственным модулем ...... Так как это единственное место, где я присваиваю значение, основанное на вызове уведомления.
Мне бы очень хотелось услышать, что другие программисты, знакомые с архитектурой pub / sub, могут сказать об этой теме ......
Пожалуйста, дайте мне ваши мысли и советы.
Спасибо.