JavaScript. Подробное руководство, 6-е издание, стр. 137
Иногда авторы модулей используют глубоко вложенные пространства имен. Если модуль с определениями классов множеств является частью обширной коллекции модулей, для него может использоваться пространство имен
<b>collections</b><b>sets</b><b>var collections; // Объявить (или повторно объявить) глобальную переменную</b><b>if (!collections) // Если объект еще не существует</b><b> collections = {}; // Создать объект пространства имен верхнего уровня</b><b>collections.sets = {} //И внутри него создать пространство имен sets.</b><b>// Теперь определить классы множеств внутри </b><b>collections.sets</b><b>collections.sets.AbstractSet = function() { ... }</b>Иногда пространство имен верхнего уровня используется для идентификации разработчика или организации - автора модуля и для предотвращения конфликтов между пространствами имен. Например, библиотека Google Closure определяет свой класс
<b>Set</b><b>goog.structs</b><b>davidflanagan.com</b><b>com.davidflanagan.collections.sets</b>При таких длинных именах для любого пользователя вашего модуля операция импортирования становится особенно важной. Однако, вместо того чтобы импортировать имена отдельных классов, программист мог бы импортировать в глобальное пространство имен весь модуль целиком:
<b>var sets = com.davidflanagan.collections.sets;</b>В соответствии с соглашениями имя файла модуля должно совпадать с его пространством имен. Модуль
<b>sets</b><b>sets.js</b><b>collections.sets</b><b>com.davidflanagan.collections.sets</b>9.9.2. Область видимости функции как частное пространство имен
Модули имеют экспортируемый ими общедоступный прикладной интерфейс (API): это функции, классы, свойства и методы, предназначенные для использования другими программистами. Однако зачастую для внутренних нужд модуля требуются дополнительные функции или методы, которые не предназначены для использования за пределами модуля. Примером может служить функция
<b>Set._v2s()</b><b>Set</b>Этого можно добиться, определив модуль (в данном случае класс
<b>Set</b><b>Set</b>Пример 9.24. Класс Set внутри функции модуля
<b>// Объявляет глобальную переменную Set и присваивает ей значение, возвращаемое</b><b>// функцией. Круглые скобки, окружающие объявление функции, свидетельствуют о том,</b><b>// что функция будет вызвана сразу после ее объявления и что присваивается значение,</b><b>// возвращаемое функцией, а не сама функция. Обратите внимание, что это выражение</b><b>// определения функции, а не инструкция, поэтому наличие имени "invocation"</b><b>// не вызывает создание глобальной переменной,</b><b>var Set = (function invocation() {</b><b> function Set() { // Эта функция-конструктор - локальная переменная,</b><b> this.values = {}; // Свойство для хранения множества</b><b> this.n = 0; // Количество значений в множестве</b><b> this.add.apply(this, arguments); // Все аргументы являются значениями,</b><b> } // добавляемыми в множество</b><b> // Далее следуют определения методов в Set.prototype.</b><b> // Для экономии места программный код опущен</b><b> Set.prototype.contains = function(value) {</b><b> // Обратите внимание, что v2s() вызывается без префикса Set._v2s()</b><b> return this.values.hasOwnProperty(v2s(value));</b><b> };</b><b> Set.prototype.size = function() { return this.n; };</b><b> Set.prototype.add = function() { /* ... */ };</b><b> Set.prototype.remove = function() { /* ... */ };</b><b> Set.prototype.foreach = function(f, context) {/*...*/>;</b><b> // Далее следуют вспомогательные функции и переменные, используемые</b><b> // методами выше. Они не являются частью общедоступного API модуля и скрыты</b><b> // в области видимости функции, благодаря чему не требуется объявлять их как</b>