JavaScript原型链是对象继承的基础,通过__proto__链接原型实现属性查找。构造函数的prototype被实例的[[Prototype]]引用,形成链式结构。使用Object.create()可实现安全继承,避免副作用;ES6的class和extends为语法糖,底层仍基于原型链。正确设置constructor指向并注意属性屏蔽,才能确保继承行为正常。掌握这些机制是理解JS面向对象的核心。

JavaScript原型链是理解对象继承机制的核心。每个对象在创建时都会关联一个原型对象,通过这个原型可以访问其属性和方法。当访问一个对象的属性时,如果该对象本身没有这个属性,JS引擎会沿着原型链向上查找,直到找到匹配属性或到达原型链末端(null)为止。
原型对象的基本使用
每个函数在定义时都会自动生成一个 prototype 属性,指向它的原型对象。而通过该函数创建的实例,其内部 [[Prototype]](可通过 __proto__ 访问)会指向这个 prototype 对象。
例如:
function Person(name) { this.name = name;}Person.prototype.greet = function() { console.log('Hello, I am ' + this.name);};const p1 = new Person('Alice');p1.greet(); // 输出: Hello, I am Alice
在这个例子中,p1 自身没有 greet 方法,但它能调用,是因为 JS 引擎在 p1.__proto__(即 Person.prototype)中找到了该方法。
实现原型链继承
通过将子构造函数的原型设置为父构造函数的一个实例,可以实现继承。这样子对象不仅能访问父对象的实例属性,还能共享原型上的方法。
基本步骤如下:
定义父构造函数并添加方法到其 prototype 定义子构造函数 将子构造函数的 prototype 指向父构造函数的实例 修复子构造函数 prototype 的 constructor 指向
function Animal(name) { this.name = name;}Animal.prototype.speak = function() { console.log(this.name + ' makes a sound.');};function Dog(name, breed) { Animal.call(this, name); // 继承实例属性 this.breed = breed;}// 设置原型链继承Dog.prototype = Object.create(Animal.prototype);Dog.prototype.constructor = Dog; // 修正 constructor// 添加子类特有方法Dog.prototype.bark = function() { console.log(this.name + ' barks loudly!');};const dog = new Dog('Max', 'Golden Retriever');dog.speak(); // Max makes a sound.dog.bark(); // Max barks loudly!
这里使用 Object.create(Animal.prototype) 创建一个以 Animal 原型为原型的新对象,确保 Dog.prototype 能正确继承 Animal 的方法,同时避免执行 Animal 构造函数时带来的副作用。
现代替代方案:class 语法
ES6 引入了 class 和 extends 关键字,让原型继承更直观:
class Animal { constructor(name) { this.name = name; } speak() { console.log(`${this.name} makes a sound.`); }}class Dog extends Animal { constructor(name, breed) { super(name); this.breed = breed; } bark() { console.log(`${this.name} barks loudly!`); }}const dog = new Dog('Max', 'Husky');dog.speak();dog.bark();
虽然写法像传统面向对象语言,但底层仍是基于原型链实现的。class 只是语法糖,本质还是函数和原型机制。
基本上就这些。掌握原型和原型链,才能真正理解 JS 中的对象和继承行为。不复杂但容易忽略细节,比如 constructor 重置和属性屏蔽问题。多实践,自然就熟了。
以上就是JS原型链怎么使用_JS原型链继承与原型对象使用方法的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1535443.html
微信扫一扫
支付宝扫一扫