// Для любого объекта возвращается строка. Для разных объектов эта функция
// будет возвращать разные строки, а для одного и того же объекта всегда
// будет возвращать одну и ту же строку. Для этого в объекте о создается свойство.
// В ES5 это свойство можно сделать неперечислимым и доступным только для чтения,
function objectld(o) {
var prop = "I **objectid**|”; // Имя частного идентификац. свойства
if (!о.hasOwnProperty(prop)) // Если объект не имеет этого свойства
о[ргор] = Set._v2s.next++; // Присвоить ему след, доступ, значение
return о[ргор]; // Вернуть идентификатор
}
};
Set._v2s.next = 100; // Начальное значение для идентификаторов объектов.
9.6.2. Пример: типы-перечисления
Перечислениями называются типы, которые могут принимать конечное количество значений, объявляемых (или «перечисляемых») при определении типа.
В языке С и его производных типы-перечисления объявляются с помощью ключевого слова enum
. В ECMAScript 5 enum
- это зарезервированное (но не используемое) слово, оставленное на тот случай, если когда-нибудь в JavaScript будут реализованы встроенные типы-перечисления. А пока в примере 9.7 демонстрируется, как можно определить собственный тип-перечисление на языке JavaScript. Обратите внимание, что здесь используется функция inherit()
из примера 6.1.
Пример 9.7 содержит единственную функцию enumeration().
Однако она не является конструктором: она не определяет класс с именем «enumeration». Но она является фабричной функцией: при каждом вызове она создает и возвращает новый класс. Ниже показано, как ее можно использовать:
// Создать новый класс Coin с четырьмя возможными значениями:
// Coin.Penny, Coin.Nickel и т. д.
var Coin = enumeration({Penny: 1, Nickel:5, Dime:10, Quarter:25});
var c = Coin.Dime; // Это экземпляр нового класса
с instanceof Coin // => true: instanceof работает
c.constructor == Coin // => true: свойство constructor работает
Coin.Quarter + 3*Coin.Nickel // => 40: значения преобразуются в числа
Coin.Dime == 10 // => true: еще одно преобразование в число
Coin.Dime > Coin.Nickel // => true: операторы отношения работают
String(Coin.Dime) + ":" + Coin.Dime // => "Dime:10": преобразов, в строку
Цель этого примера состоит в том, чтобы продемонстрировать, что классы в языке JavaScript являются более гибкими и динамичными, чем статические классы в таких языках, как C++ и Java.
Пример 9.7 Типы-перечисления в JavaScript
// Эта функция создает новый тип-перечисление. Объект в аргументе определяет
// имена и значения каждого экземпляра класса. Возвращает функцию-конструктор,
// идентифицирующую новый класс. Отметьте, однако, что конструктор возбуждает
// исключение: его нельзя использовать для создания новых экземпляров типа.
// Возвращаемый конструктор имеет свойства, которые отображают имена в значения,
// а также массив значений values и функцию foreach() для выполнения итераций
function enumeration(namesToValues) {
// Фиктивный конструктор, который будет использоваться как
// возвращаемое значение.
var enumeration = function() { throw "Нельзя создать экземпляр класса” +
Enumeration"; };
// Перечислимые значения наследуют объект this,
var proto = enumeration.prototype = {
constructor: enumeration, // Идентификатор типа
toString: function() { return this.name; }, // Возвращает имя
valueOf: function() { return this.value; }, // Возвращает значение
toJSON: function() { return this.name; } // Для сериализации
};
enumeration.values = []; // Массив перечислимых объектов-значений
// Теперь создать экземпляры нового типа.
for(name in namesToValues) { // Для каждого значения
var е = inherit(proto); // Создать объект для его представления
e.name = name; // Дать ему имя
е.value = namesToValues[name]; // И значение
enumeration[name] = е; // Сделать свойством конструктора
enumeration.values.push(e); // И сохранить в массиве values
}
// Метод класса для обхода экземпляров класса в цикле
Читать дальше
Конец ознакомительного отрывка
Купить книгу