handler.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 handler.has()
method is a trap for the [[HasProperty]]
object internal method, which is used by operations such as the in
operator.
Try it
Syntax
new Proxy(target, {
has(target, property) {
}
})
Parameters
Return value
The has()
method must return a Boolean
indicating whether or not the property exists. Other values are coerced to booleans.
Description
Interceptions
This trap can intercept these operations:
- The
in
operator:foo in proxy
with
check:with(proxy) { (foo); }
Reflect.has()
Or any other operation that invokes the [[HasProperty]]
internal method.
Invariants
The proxy's [[HasProperty]]
internal method throws a TypeError
if the handler definition violates one of the following invariants:
- A property cannot be reported as non-existent, if it exists as a non-configurable own property of the target object. That is, if
Reflect.getOwnPropertyDescriptor()
returnsconfigurable: false
for the property ontarget
, the trap must returntrue
. - A property cannot be reported as non-existent, if it exists as an own property of the target object and the target object is not extensible. That is, if
Reflect.isExtensible()
returnsfalse
ontarget
, andReflect.getOwnPropertyDescriptor()
returns a property descriptor for the property ontarget
, the trap must returntrue
.
Examples
Trapping the in operator
The following code traps the in
operator.
const p = new Proxy(
{},
{
has(target, prop) {
console.log(`called: ${prop}`);
return true;
},
},
);
console.log("a" in p);
// "called: a"
// true
The following code violates an invariant.
const obj = { a: 10 };
Object.preventExtensions(obj);
const p = new Proxy(obj, {
has(target, prop) {
return false;
},
});
"a" in p; // TypeError is thrown
Specifications
Specification |
---|
ECMAScript Language Specification # sec-proxy-object-internal-methods-and-internal-slots-hasproperty-p |
Browser compatibility
BCD tables only load in the browser