js怎么动态修改对象的原型

来源:开发教程作者:宋琮安头衔:草根站长
导读:本期聚焦于小伙伴创作的《js怎么动态修改对象的原型》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《js怎么动态修改对象的原型》有用,将其分享出去将是对创作者最好的鼓励。

在JavaScript中,每个对象都有一个隐式的原型属性,指向其构造函数的原型对象,动态修改对象的原型可以改变对象的属性查找链,实现灵活的继承或行为扩展。常见的动态修改对象原型的方式有两种,分别是使用__proto__属性和Object.setPrototypeOf方法。

js怎么动态修改对象的原型

使用__proto__属性修改原型

__proto__是对象的一个访问器属性,本质上是对Object.getPrototypeOfObject.setPrototypeOf的封装,直接对该属性赋值即可动态修改对象的原型。不过需要注意的是,__proto__并不是ECMAScript标准的强制要求,部分环境下可能不支持。

示例代码如下:

// 定义原始原型对象
const originalProto = {
  sayHi: function() {
    console.log('原始原型的方法');
  }
};

// 定义新的原型对象
const newProto = {
  sayHello: function() {
    console.log('新原型的方法');
  }
};

// 创建对象,默认原型为originalProto
const obj = Object.create(originalProto);
obj.sayHi(); // 输出:原始原型的方法

// 动态修改obj的原型为newProto
obj.__proto__ = newProto;
obj.sayHello(); // 输出:新原型的方法
// 此时originalProto上的方法已经无法访问
obj.sayHi(); // 输出:undefined

使用Object.setPrototypeOf方法修改原型

Object.setPrototypeOf是ES6正式引入的标准方法,用于设置一个指定对象的原型到另一个对象,兼容性比__proto__更好,是官方推荐的修改原型的方式。

语法结构为:Object.setPrototypeOf(obj, prototype),其中obj是要修改原型的对象,prototype是新的原型对象,可以是null或者对象。

示例代码如下:

// 定义基础原型
const baseProto = {
  getInfo: function() {
    return '基础原型信息';
  }
};

// 定义扩展原型
const extendProto = {
  getDetail: function() {
    return '扩展原型详情';
  }
};

// 创建对象
const user = Object.create(baseProto);
console.log(user.getInfo()); // 输出:基础原型信息

// 动态修改原型
Object.setPrototypeOf(user, extendProto);
console.log(user.getDetail()); // 输出:扩展原型详情
console.log(user.getInfo()); // 输出:undefined

// 也可以将原型设置为null
Object.setPrototypeOf(user, null);
console.log(user.getDetail); // 输出:undefined

两种方式的对比

我们可以通过下表查看两种修改原型方式的特点:

方式标准性兼容性推荐程度
__proto__赋值非标准(虽被多数环境支持)较旧环境可能不支持不推荐
Object.setPrototypeOfES6标准方法现代浏览器、Node.js均支持推荐

注意事项

  • 动态修改对象原型会影响该对象后续所有的属性查找行为,如果新原型没有覆盖旧原型的属性,旧原型的属性将无法被访问。
  • 频繁修改对象原型会导致JavaScript引擎的属性查找优化失效,可能影响代码执行性能,除非必要场景,否则不建议频繁操作。
  • 如果要将对象的原型设置为null,该对象将不再拥有任何继承的原型方法,比如toString等基础方法也无法使用。
  • 修改原型操作仅对当前对象生效,不会影响该对象原本构造函数的原型,也不会影响其他基于原构造函数创建的对象。

实际应用场景

动态修改对象原型的常见场景包括:运行时扩展对象的行为、临时替换对象的继承链实现特定逻辑、在不修改构造函数的情况下为单个对象添加原型方法等。比如下面的例子,为单个对象临时添加日志功能:

// 基础对象
const tool = {
  doWork: function() {
    console.log('执行工作');
  }
};

// 带日志的原型
const logProto = {
  doWork: function() {
    console.log('开始执行工作');
    // 调用原原型的方法
    Object.getPrototypeOf(this).doWork.call(this);
    console.log('工作执行完成');
  }
};

// 为tool对象动态添加日志能力
Object.setPrototypeOf(tool, logProto);
tool.doWork();
// 输出:
// 开始执行工作
// 执行工作
// 工作执行完成

通过上述方式,我们可以在不修改原对象结构的情况下,动态为对象扩展新的行为,实现更灵活的逻辑处理。

JavaScript原型修改Object_setPrototypeOf__proto__对象继承修改时间:2026-06-23 16:03:31

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。