IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 原型链详细概念和雷雨的验证 -> 正文阅读

[JavaScript知识库]原型链详细概念和雷雨的验证

首先是对原型链的定义:

????????普通构造函数的原型 继承自 顶级构造函数的原型
? ? ? ? 实例对象找原型,优先自己,没有找上级.

?这里先定义一个构造函数? Student

function Student(name, age) {
            this.name = name
            this.age = age
        }

再说说prototype

????????每个函数都有一个 prototype 属性,每一个对象都会关联的一个属性,而这里所说的原型链就是关于原型对象的继承,原型函数获取方式,以上面Student为例

console.log(Student.prototype) // 查看函数的原型对象

? ? 结果如图:? ??,即是构造函数Student本身

创建一个实例后,他们之间满足原型三角关系:如图所示

这里就有一个概念,构造函数时父亲,原型对象是母亲,而实例化就是孩子

实例化对象.__proto__? ? 表示找孩子的母亲,即实例化对象的上级原型函数

?

let stu = new Student('bobo', 18, '男')  //实例化
console.log(stu.__proto__ === Student.prototype)  //子级找妈妈 等于 爸爸找老婆  true

?图中顶级原型构造函数:他是神,创建了所有的原型对象.只要记得这个就好,而这个父亲既然是构造函数,就一定会有原型对象,也就是顶级原型对象.我们还可以把我们定义的Student的圆形函数看成是顶级原型函数的孩子,那么他们三个之间也满足原型三角关系.

? ? ? ?而原型链的方法继承就在绿色区域向下继承,如果闲着蛋疼,还可以把顶级原型函数的母亲找出来,你以为她会报错吗?不,是NULL,虽然并没有什么用😐。

console.log(stu.__proto__.__proto__.__proto__) //null

继承的例子给大家举一个。

 //  继承关系
        Object.prototype.happy = function () {
            console.log('哈哈')
        }
        stu.happy()    // 哈哈

? ? ? ? 这里我是给最顶级的构造函数的原型函数挂载了方法(挂载?就是在原型上加函数的意思)可以看到,它继承给了所有对象的原型函数,因此但凡是个对象都会有这个方法,都可以调用。

? ? ? ? 而实际上,顶级原型构造函数也是有父亲母亲的,这里需要引入一个概念,Function,一切的普通构造函数都是由Function这个构造函数创建的实例,也就是Function的孩子,因为,原型链最可怕的地方来了,本人呕心沥血,深究其中关系,完整的做完了这张图

????????

?因此这里错综复杂的关系变得更多起来。

? ? ? ? ?而原本的普通构造函数,也有了双亲,即Function和与之对应的原型对象,因此也有原型三角关系

        // 此时:构造函数Student角色转换,只是Function的孩子
        // 既然是孩子:三角关系
        // 构造函数:必有原型对象
        console.log(Function.prototype)         // f:虽然是函数,但是就是对象
          // 是原型对象:必有constructor指向构造函数
        console.log(Function.prototype.constructor === Function)    // true

        // 孩子找爸爸:Student,只能通过找妈妈来找
        console.log(Student.__proto__.constructor === Function)     // true

? ? ? ? 要是有人问图中所示的Function怎么没有,我也不知道,就好像人是由女娲造出来的,你问我女娲怎么来的,盘古怎么来的一样,需要问到了尽头,因为这就是作者所创,已经到了尽头。而且是可以用代码证明这件事的。而这里的思维:极度困难!!!!慎看,因为已经不是简单的三角关系了,雷雨听过吧······

????????

        // 1. 构造函数Function是所有构造函数的创建者:自己也是自己创建的
        console.log(Function.__proto__ == Function.prototype)       // true

        // 2. Object也是由Function创建
        console.log(Object.__proto__ == Function.prototype)         // true

        // 3. 所有原型对象:都由Object创建,Function的原型也由Object创建
        console.log(Function.prototype.__proto__ == Object.prototype)   //true

总结:最后这混乱关系当做笑话看看即可(看似成立,实则不存在)

? ? ? ? Function和Object以及Function.prototype和Object.prototype都遵循原型的三角关系,因为三角关系的原因,JS的作者为了有个源头,强行关联的内容,嘿嘿没想到吧,但是这个是不是可以在你去面试的时候去虐面试官了😶,面试官:"wc,nb"

? ? ? ? 而这里的本质四个东西,即顶级那一排,都不是这么来的:是由JS引擎自动产生的,彼此之间没有创建的.

????????

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-22 10:51:58  更:2021-10-22 10:52:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/29 19:46:24-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计