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 2016年9月.
Reflect.has()
静态方法的作用类似于 in
运算符,但它以函数的形式实现。
尝试一下
const object = {
property1: 42,
};
console.log(Reflect.has(object, "property1"));
// 期望输出:true
console.log(Reflect.has(object, "property2"));
// 期望输出:false
console.log(Reflect.has(object, "toString"));
// 期望输出:true
语法
js
Reflect.has(target, propertyKey)
参数
target
-
要查找该属性的目标对象。
propertyKey
-
要检测的属性名称。
返回值
Boolean
,表示 target
是否具有该属性。
异常
TypeError
-
如果
target
不是对象,则抛出此异常。
描述
Reflect.has()
提供了一种用于检查属性是否存在于对象中的反射语义。也就是说,Reflect.has(target, propertyKey)
在语义上等价于:
js
propertyKey in target;
Reflect.has()
会调用 target
的 [[HasProperty]]
对象内部方法。
示例
>使用 Reflect.has()
js
Reflect.has({ x: 0 }, "x"); // true
Reflect.has({ x: 0 }, "y"); // false
// 对原型链上的属性也会返回 true
Reflect.has({ x: 0 }, "toString");
// 带有 .has() 处理器方法的 Proxy
obj = new Proxy(
{},
{
has(t, k) {
return k.startsWith("door");
},
},
);
Reflect.has(obj, "doorbell"); // true
Reflect.has(obj, "dormitory"); // false
Reflect.has
会对任何继承的属性返回 true
,这一点与 in
运算符相同:
js
const a = { foo: 123 };
const b = { __proto__: a };
const c = { __proto__: b };
// 原型链为:c -> b -> a
Reflect.has(c, "foo"); // true
规范
Specification |
---|
ECMAScript® 2026 Language Specification> # sec-reflect.has> |
浏览器兼容性
Loading…