Reflect.has()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2016.
The Reflect.has()
static method is like the in
operator, but
as a function.
Try it
Syntax
Reflect.has(target, propertyKey)
Parameters
target
-
The target object in which to look for the property.
propertyKey
-
The name of the property to check.
Return value
A Boolean
indicating whether or not the target
has the property.
Exceptions
TypeError
-
Thrown if
target
is not an object.
Description
Reflect.has()
provides the reflective semantic of checking if a property is in an object. That is, Reflect.has(target, propertyKey)
is semantically equivalent to:
propertyKey in target;
Reflect.has()
invokes the [[HasProperty]]
object internal method of target
.
Examples
Using Reflect.has()
Reflect.has({ x: 0 }, "x"); // true
Reflect.has({ x: 0 }, "y"); // false
// returns true for properties in the prototype chain
Reflect.has({ x: 0 }, "toString");
// Proxy with .has() handler method
obj = new Proxy(
{},
{
has(t, k) {
return k.startsWith("door");
},
},
);
Reflect.has(obj, "doorbell"); // true
Reflect.has(obj, "dormitory"); // false
Reflect.has
returns true
for any inherited properties, like the in
operator:
const a = { foo: 123 };
const b = { __proto__: a };
const c = { __proto__: b };
// The prototype chain is: c -> b -> a
Reflect.has(c, "foo"); // true
Specifications
Specification |
---|
ECMAScript Language Specification # sec-reflect.has |
Browser compatibility
BCD tables only load in the browser