当前位置: 首页 > news >正文

原型与原型链

什么是原型(对象)

在JavaScript中,每个对象都具有一个原型对象prototype,目的是:利用原型对象实现在同一原型链中的原型方法共享

在理解原型对象前,需要先了解什么是构造函数

构造函数

用来初始化对象的特殊函数,通过new 对象名(参数)来创建对象实例

构造函数实例化过程:

        1. 通过new创建一个空的对象{}

        2. 构造函数的this指向改对象

        3. 指向构造函数,向该对象赋值

        4. 返回新对象

//构造方法
function Parent(name, age) {this.name = name;this.age = age;this.fn = function () { }
}//创建实例
const parent = new Parent('张三', 18);

原型

  • 每一个构造函数都有一个prototype属性,该属性指向该函数的原型对象
  • 原型对象中的属性对其构造函数实例化的对象共享
  • 可以将共用的方法写在prototype中,保证对象实例不会多次创建函数,节省内存
  • 构造函数和原型对象中的this都指向实例对象
//构造方法
function Parent(name, age) {this.name = name;this.age = age;this.fn = function () { }
}
Parent.prototype.fn2 = function () { }
//创建实例
const p1 = new Parent('张三', 18);
const p2 = new Parent('李四', 19)
console.log(p1.fn2 === p2.fn2) // true

 constructor属性

在每个prototype属性中,都有一个constructor属性,它指向该原型的构造函数

作用:

        方便在给原型对象一次性进行多次赋值时,将原型指回其构造函数

对象原型__proto__

  • 每个实例对象中都有一个__proto__属性,该属性指向其实例的原型对象
  • 正是因为有__proto__的存在,才能使得实例对象可以访问构造函数原型对象中的方法

 总结

  • 构造函数通过prototype指向它的原型对象
  • 原型对象通过constructor指向它的构造函数
  • 通过构造函数实例化的对象中的__proto__属性,指向其构造函数的原型对象

原型继承

根据原型的特性,可以实现对象之间的继承

上述代码,Woman构造函数公共prototype继承了Person对象,使得所有由Woman实例化出来的对象,都可以使用Person对象中的属性。
通过prototype 接收 new Person实例,保证所有子类不会影响父类中的结构
而在Woman构造函数中,可以编写Woman私有的属性

弊端,若父类中定义了引用数据类型,被子类实例的对象所修改,由于他们共同引用同一地址,其他子类也会受到影响

构造函数继承 

想要解决上述问题,可以通过在子类创建实例时去执行父类构造函数,并修改this指向为子类实例

 组合式继承

结合原型链继承和构造函数继承,弥补了两者的缺点

 原型链查找

 每个原型对象proptotype中也有一个__proto__属性,它指向其上一级的原型对象

通过这一属性,可以得到一条原型链的查找规则

  1. 每当需要访问一个对象中是否存在一个属性时
  2. 先去该实例对象中的私有属性中进行查找
  3. 若没查到,通过实例对象中的__proto__属性去实例对象的原型prototype中进行查找
  4. 若还没查到,则根据prototype属性去它的上一级原型中进行查找
  5. 直到查到Object的原型对象中
  6. 最终Object的prototype的__proto__属性指向null

利用instanceof方法可以查找某实例对象的原型是否在某个原型链中

Class

class作为es6中原型的语法糖,极大的简化了原型以及原型继承的写法

http://www.lryc.cn/news/516783.html

相关文章:

  • 【Linux】信号处理
  • 5个不同类型的mysql数据库安装
  • python学习笔记—12—布尔类型、if语句
  • 分数阶傅里叶变换代码 MATLAB实现
  • 《数据结构》期末考试测试题【中】
  • openwrt 清缓存命令行
  • RP2K:一个面向细粒度图像的大规模零售商品数据集
  • .NET Core FluentAPI
  • 【C++数据结构——查找】顺序查找(头歌实践教学平台习题)【合集】
  • HTTP Scheme 通常指的是在 URL 中用于指定使用 HTTP 协议的方案(scheme)
  • 基于Matlab的变压器仿真模型建模方法(13):单相升压自耦变压器的等效电路和仿真模型
  • 【Vue.js】监听器功能(EventListener)的实际应用【合集】
  • 【Shell脚本】Docker构建Java项目,并自动停止原镜像容器,发布新版本
  • 【iOS Swift Moya 最新请求网络框架封装通用】
  • 前端批量下载文件
  • 【pytorch-lightning】架构一览
  • MongoDB相关使用问题
  • DevSecOps自动化在安全关键型软件开发中的实践、Helix QAC Klocwork等SAST工具应用
  • 常见的显示器分辨率及其对应的像素数量
  • TDengine + MQTT :车联网时序数据库如何高效接入
  • maven的中国镜像有哪些
  • ModelScope ms-swift:轻量级模型微调框架
  • 深度解析与实践:HTTP 协议
  • Zookeeper是如何解决脑裂问题的?
  • 《Opencv》基础操作详解(5)
  • AI大模型-提示工程学习笔记2
  • AWS ELB基础知识
  • 我用Ai学Android Jetpack Compose之Text
  • Robot---奇思妙想轮足机器人
  • springcloud 介绍