Книга: JavaScript. Подробное руководство, 6-е издание
6.4. Проверка существования свойств
6.4. Проверка существования свойств
Объекты в языке JavaScript можно рассматривать как множества свойств, и нередко бывает полезно иметь возможность проверить принадлежность к множеству - проверить наличие в объекте свойства с данным именем. Выполнить такую проверку можно с помощью оператора in
, с помощью методов hasOwnProperty()
и propertylsEnumerable()
или просто обратившись к свойству.
Оператор in
требует, чтобы в левом операнде ему было передано имя свойства (в виде строки) и объект в правом операнде. Он возвращает true
, если объект имеет собственное или унаследованное свойство с этим именем:
var о = { х: 1 }
”х" in о; // true: о имеет собственное свойство "х"
"у" in о; // false: о не имеет свойства "у"
"toString" in о; // true: о наследует свойство toString
Метод hasOwnProperty()
объекта проверяет, имеет ли объект собственное свойство с указанным именем. Для наследуемых свойств он возвращаетfalse
:
var о = { х: 1 }
о.hasOwnPropertyC'x"); // true: о имеет собственное свойство х
о.hasOwnPropertyC'y"); // false: не имеет свойства у
о.hasOwnProperty("toString"); // false: toString - наследуемое свойство
Метод propertylsEnumerable()
накладывает дополнительные ограничения по сравнению с hasOwnProperty()
. Он возвращает true
, только если указанное свойство является собственным свойством, атрибут enumerable
которого имеет значение true
. Свойства встроенных объектов не являются перечислимыми. Свойства, созданные обычной программой на языке JavaScript, являются перечислимыми, если не был использован один из методов ECMAScript 5, представленных ниже, которые делают свойства неперечислимыми.
var о = inherit({ у: 2 }); о.х = 1;
о.propertyIsEnumerable("x“); // true: о имеет собств. перечислимое свойство х
о.propertyIsEnumerable("у"); // false: у - унаследованное свойство, не собств.
Object.prototype.propertyIsEnumerable("toString”); // false: неперечислимое
var о = { х: 1 }
о.х !== undefined; // true: о имеет свойство х
о.у !== undefined; // false; о не имеет свойства у
o.toString !== undefined; // true: о наследует свойство toString
Однако оператор in
отличает ситуации, которые неотличимы при использовании представленного выше приема на основе обращения к свойству. Оператор in
отличает отсутствие свойства от свойства, имеющего значение undefined
. Взгляните на следующий пример:
var о = { х: undefined } // Свойству явно присвоено значение undefined
о.х !== undefined // false: свойство имеется, но со значением undefined
о.у !== undefined // false: свойство не существует
"х" in о // true: свойство существует
"у” in о // false: свойство не существует
delete о.х; // Удалить свойство х
"х" in о // false: оно больше не существует
Обратите внимание, что в примере выше использован оператор !==
, а не !=
. Опера¬торы !==
и ===
отличают значения undefined
и null
, хотя иногда в этом нет необходимости:
// Если о имеет свойство X, значение которого отлично от null и undefined,
// то удвоить это значение,
if (о.х != null) о.х *= 2;
// Если о имеет свойство х, значение которого не может быть преобразовано в false,
// то удвоить это значение. Если х имеет значение undefined, null, false, 0 или NaN,
// оставить его в исходном состоянии,
if (о.х) о.х *= 2;
- 11.2. СВОЙСТВА ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ
- 5. Null-значения и проверка условий
- 4. Свойства унарных операций
- 3. Свойства бинарных операций
- Ключевые свойства форм
- 1.1.5. Свойства и особенности туруслуг и турпродуктов
- 12.1. Автоматизированная проверка безопасности
- 12.3. Проверка конфигурации
- Проверка, что сервер Firebird запущен
- Свойства меню Пуск
- Изменение свойств ярлыка
- Просмотр свойств объектов