Вход/Регистрация
JavaScript. Подробное руководство, 6-е издание
вернуться

Флэнаган Дэвид

Шрифт:

}

Обратите внимание, что выражения в этом примере, следующие за ключевыми словами case, являются функциями. Если бы мы использовали оператор

typeof
или извлекали значение атрибута
class
объекта, они были бы строками.

Для приема, основанного на использовании свойства

constructor
, характерны те же проблемы, что и для приема на основе оператора
instanceof
. Он не всегда будет работать при наличии нескольких контекстов выполнения (например, при наличии нескольких фреймов в окне броузера), совместно использующих общие значения. Каждый фрейм имеет собственный набор функций-конструкторов: конструктор Array в одном фрейме не будет считаться идентичным конструктору Array в другом фрейме.

Кроме того, язык JavaScript не требует, чтобы каждый объект имел свойство

constructor
: это всего лишь соглашение, по которому по умолчанию объект-прототип создается для каждой функции, и очень просто по ошибке или преднамерение опустить свойство
constructor
в прототипе. Например, первые два класса в этой главе (в примерах 9.1 и 9.2) были определены так, что их экземпляры не имеют свойства
constructor
.

9.5.3. Имя конструктора

Основная проблема использования оператора

instanceof
или свойства
constructor
для определения класса объекта проявляется при наличии нескольких контекстов выполнения и, соответственно, при наличии нескольких копий функций-конструкторов. Эти функции могут быть совершенно идентичными, но разными объектами, как следствие, не равными друг другу.

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

Array
в одном окне не будет равен конструктору
Array
в другом окне, но их имена будут равны. Некоторые реализации JavaScript обеспечивают доступ к имени функции через нестандартное свойство
name
объекта функции. Для реализаций, где свойство
name
отсутствует, можно преобразовать функцию в строку и извлечь имя из нее. (Этот прием использовался в разделе 9.4, где демонстрировалось добавление в класс
Function
метода
getName
.)

В примере 9.4 определяется функция

type,
возвращающая тип объекта в виде строки. Простые значения и функции она обрабатывает с помощью оператора
typeof
. Для объектов она возвращает либо значение атрибута
class
, либо имя конструктора. В своей работе функция
type
использует функцию
classof
из примера 6.4 и метод
Function.getName
из раздела 9.4. Для простоты реализация этой функции и метода включена в пример.

Пример 9.4. Функция type для определения типа значения

/**

* Возвращает тип значения в виде строки:

* -Если о - null, возвращает "null", если о - NaN, возвращает "пап”.

* -Если typeof возвращает значение, отличное от "object", возвращает это значение.

* (Обратите внимание, что некоторые реализации идентифицируют объекты

* регулярных выражений как функции.)

* -Если значение атрибута class объекта о отличается от "Object",

* возвращает это значение.

* -Если о имеет свойство constructor, а конструктор имеет имя, возвращает

* имя конструктора.

* -Иначе просто возвращает "Object".

**/

function type(o) {

var t, c, n; // type, class, name

// Специальный случай для значения null:

if (о === null) return "null":

// Другой специальный случай: NaN - единственное значение, не равное самому себе:

if (о !== о) return "nan";

// Применять typeof для любых значений, отличных от "object".

// Так идентифицируются простые значения и функции,

if ((t = typeof о) !== "object") return t;

// Вернуть класс объекта, если это не "Object".

// Так идентифицируется большинство встроенных объектов,

if ((с = classof(o)) !== "Object") return с;

  • Читать дальше
  • 1
  • ...
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137
  • 138
  • 139
  • 140
  • ...

Ебукер (ebooker) – онлайн-библиотека на русском языке. Книги доступны онлайн, без утомительной регистрации. Огромный выбор и удобный дизайн, позволяющий читать без проблем. Добавляйте сайт в закладки! Все произведения загружаются пользователями: если считаете, что ваши авторские права нарушены – используйте форму обратной связи.

Полезные ссылки

  • Моя полка

Контакты

  • chitat.ebooker@gmail.com

Подпишитесь на рассылку: