Object.getPrototypeOf() 是获取对象原型的标准方法,返回其内部 [[Prototype]] 指向的对象;接收对象参数,对非对象值抛 TypeError;不推荐使用非标准的__proto__属性。

Object.getPrototypeOf() 是 JavaScript 中用于获取指定对象的原型(即其内部 [[Prototype]] 指向的对象)的标准方法。它返回对象的直接原型,是替代非标准的 __proto__ 属性、安全读取原型链的推荐方式。
基本用法和返回值
语法很简单:
-
Object.getPrototypeOf(obj)—— 接收一个对象,返回它的原型对象; - 如果
obj不是对象(如 null、原始值),会抛出TypeError; - 对于普通对象,通常返回
Object.prototype; - 对于数组,返回
Array.prototype;对于函数,返回Function.prototype; - 对于通过
Object.create(null)创建的对象,返回null(无原型)。
与 __proto__ 的区别
__proto__ 是早期浏览器实现的非标准属性,虽被广泛支持,但已不推荐使用:
-
__proto__既是 getter 也是 setter,可读可写,存在性能与安全风险; -
Object.getPrototypeOf()仅用于读取,语义明确、行为稳定; - 修改原型应使用
Object.setPrototypeOf()(谨慎使用),而非赋值__proto__; - ES6+ 环境中,
Object.getPrototypeOf()是规范要求的唯一标准读取方式。
配合原型链判断的常见场景
常与 isPrototypeOf() 或 instanceof 配合,用于类型或继承关系检测:
立即学习“Java 免费学习笔记(深入)”;
- 判断某对象是否在另一对象的原型链上:
Array.prototype.isPrototypeOf(arr); - 手动遍历原型链:
let proto = Object.getPrototypeOf(obj); while (proto) {console.log(proto); proto = Object.getPrototypeOf(proto); }; - 检查是否为“纯净”对象(排除 Array、Date 等):可结合
constructor.name或toString.call()使用; - 在类继承调试中,快速确认子类实例的原型是否正确指向父类原型。
注意事项和边界情况
使用时需留意几个易错点:
- 不能对
null或undefined调用,否则报错;可用obj != null && typeof obj === 'object'预检; - 对原始值(如字符串字面量
"abc")会自动装箱,返回对应包装对象的原型(String.prototype),但不建议依赖此行为; - 箭头函数没有自己的
this和prototype,但仍是函数对象,其原型仍是Function.prototype; - 在 Proxy 对象上使用,返回的是被代理目标的原型,不是 Proxy 本身的原型。