js原型和原型链的概念

原型和原型链是JavaScript中重要的概念,理解它们对于理解如何构建对象以及继承特性非常关键。

  1. 原型:

在JavaScript中,每个函数都有一个特殊的属性叫做prototype。这个属性指向一个对象,这个对象作为原型,该函数所创建的所有对象都将继承这个原型对象的属性和方法。

例如:

javascript 复制代码
function Person() {}
 
Person.prototype.name = 'John';
Person.prototype.age = 30;
Person.prototype.job = 'Developer';
 
var person1 = new Person();
console.log(person1.name); // 'John'

在这个例子中,Person函数的prototype属性指向一个包含nameagejob属性的对象。当我们创建Person的新实例person1时,这个实例会从Person.prototype中继承这些属性。

  1. 原型链:

JavaScript中的原型链是一个对象链,用于继承和链式查找属性和方法。当尝试访问对象的属性或方法时,如果这个对象本身没有这个属性或方法,那么JavaScript会在这个对象的原型(一个对象)上查找这个属性或方法。如果原型也不存在这个属性或方法,那么JavaScript会在原型的原型上查找,直到找到这个属性或方法,或者直到找到一个原型是null的对象为止,这个过程就是原型链。

例如:

javascript 复制代码
function Person() {}
 
Person.prototype.name = 'John';
Person.prototype.age = 30;
Person.prototype.job = 'Developer';
 
var person1 = new Person();
console.log(person1.name); // 'John'
 
// 修改原型对象
Person.prototype = {
  name: 'Alice',
  age: 25,
  job: 'Designer'
};
 
var person2 = new Person();
console.log(person2.name); // 'Alice'
console.log(person1.name); // 'John'

在这个例子中,person1person2都是Person的实例,但是它们的原型链指向的是Person.prototype的不同实例。因此,person1person2name属性是从不同的原型链中查找的,得到了不同的值。

注意:当修改原型对象时,已经创建的实例不会受到影响,它们会继续使用原来的原型。

3、实现类的继承

实现类的继承分为两步:

  • 继承构造函数中的属性和方法(构造器继承)
  • 继承对象原型中的属性和方法(原型链继承)

在研究他们之前,我们首先建立两个类

javascript 复制代码
function father() {
    //这些属性在father实例对象上
    this.name = "cry"
    this.age = 50
}
//这些方法在father原型对象上
father.prototype.getName = function () {
    return "父亲叫" + this.name
}
father.prototype.getAge = function () {
    return "父亲他今年" + this.age + "岁了"
}

//子类(姓名,年龄)
function child() {

}

我们首先实现实例对象的继承

javascript 复制代码
function child() {
    //继承第一步,实例对象的属性继承
    father.call(this)//call可以把child的上下文传进Father里进行属性赋值
}
//现在你已经可以访问father的name属性和age属性了
var c1 = new child()
console.log(c1.name, c1.age)
//但是我们还是没有办法访问father原型上的方法
console.error("error",c1.getAge())
相关推荐
苦夏木禾3 分钟前
js请求避免缓存的三种方式
开发语言·javascript·缓存
超级土豆粉11 分钟前
Turndown.js: 优雅地将 HTML 转换为 Markdown
开发语言·javascript·html
乆夨(jiuze)38 分钟前
记录H5内嵌到flutter App的一个问题,引发后面使用fastClick,引发后面input输入框单击无效问题。。。
前端·javascript·vue.js
小彭努力中1 小时前
141.在 Vue 3 中使用 OpenLayers Link 交互:把地图中心点 / 缩放级别 / 旋转角度实时写进 URL,并同步解析显示
前端·javascript·vue.js·交互
wei_shuo1 小时前
飞算 JavaAI 开发助手:深度学习驱动下的 Java 全链路智能开发新范式
java·开发语言·飞算javaai
熊猫钓鱼>_>1 小时前
用Python解锁图像处理之力:从基础到智能应用的深度探索
开发语言·图像处理·python
小飞悟1 小时前
前端高手才知道的秘密:Blob 居然这么强大!
前端·javascript·html
code_YuJun1 小时前
Promise 基础使用
前端·javascript·promise
GO兔1 小时前
开篇:GORM入门——Go语言的ORM王者
开发语言·后端·golang·go
Codebee1 小时前
OneCode自主UI设计体系:架构解析与核心实现
前端·javascript·前端框架