js的原型、原型链

原型(prototype)

定义

在JavaScript中,每个对象都有一个内部属性[Prototype],这个属性指向该对象的原型对象。原型对象也是一个普通对象,它同样有自己的原型对象,以此类推,直到最顶层的原型对象 Object.prototype,其原型为null。

作用

原型的主要作用是对象的属性和方法共享。当要访问一个对象的属性和方法时,JavaScript会先在该对象本身查找,如果找不到,则会往该对象的原型对象中查找,以此类推,直至找到该属性或方法或到达原型链的末尾(即null)。

示例代码

js 复制代码
// 定义一个构造函数
function Person(name, age) {
    this.name = name;
    this.age = age;
}

// 在函数的原型对象上构造一个方法
Person.prototype.sayHello = function () {
    console.log(`Hello, my name is ${this.name} and I'm ${this.age} years old.`);
}

// 创建实例
var person1 = new Person('Abby', '34')

// 访问原型对象的方法
person1.sayHello()

在上述示例中,Person 是一个构造函数,通过 Person.prototype 可以访问其原型对象。我们在原型对象上添加了 sayHello 方法,那么所有通过 new Person() 创建的实例都可以共享这个方法。当调用 person1.sayHello() 时,JavaScript 首先在 person1 对象本身查找 sayHello 方法,没找到就会去 person1 的原型对象(即 Person.prototype)中查找,从而找到并执行该方法。

原型链(Prototype Chain)

定义

原型链是由对象的多个原型对象以此连接而成的链条。当访问一个对象的属性或方法时,JavaScript会按照原型链的顺序依次查找,直到找到该属性或方法或到达原型链的末尾(null)。

示例代码

javascript 复制代码
function Animal() {
    this.eat = function() {
        console.log('Animal is eating.');
    };
}

function Dog() {
    this.bark = function() {
        console.log('Dog is barking.');
    };
}

// 设置 Dog 的原型为 Animal 的实例
Dog.prototype = new Animal();

const dog = new Dog();

// 调用 Dog 自身的方法
dog.bark(); 
// 调用 Dog 原型链上的方法
dog.eat(); 

在这个示例中,Dog 构造函数的原型被设置为 Animal 的实例,这样就形成了一个原型链:dog 对象 -> Dog.prototypeAnimal 的实例) -> Animal.prototype -> Object.prototype -> null。当调用 dog.eat() 时,JavaScript 会沿着原型链查找,最终在 Animal 的实例中找到 eat 方法并执行。

原型和原型链是 JavaScript 实现继承的重要机制,它们允许对象之间共享属性和方法,提高了代码的复用性。

相关推荐
Moment6 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
爱敲代码的小鱼7 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax
铅笔侠_小龙虾9 小时前
Flutter 实战: 计算器
开发语言·javascript·flutter
大模型玩家七七9 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
2501_944711439 小时前
JS 对象遍历全解析
开发语言·前端·javascript
发现一只大呆瓜10 小时前
虚拟列表:支持“向上加载”的历史消息(Vue 3 & React 双版本)
前端·javascript·面试
阔皮大师10 小时前
INote轻量文本编辑器
java·javascript·python·c#
lbb 小魔仙10 小时前
【HarmonyOS实战】React Native 表单实战:自定义 useReactHookForm 高性能验证
javascript·react native·react.js
_codemonster10 小时前
Vue的三种使用方式对比
前端·javascript·vue.js
千寻girling11 小时前
Koa.js 教程 | 一份不可多得的 Node.js 的 Web 框架 Koa.js 教程
前端·后端·面试