美文网首页
js 原型与原型链小结

js 原型与原型链小结

作者: 梦舟缘钓 | 来源:发表于2019-08-29 16:17 被阅读0次

一、基本理论

  1. js 万物皆对象

  2. 对象分为函数对象与普通对象

  3. 每个函数都有一个prototype属性

  4. 每个对象都有一个__proto__属性

  5. prototype属性指向该函数的原型对象,是属性的集合

  6. __proto__属性指向创建该对象的构造函数的原型

  7. constructor属性指向函数本身

  8. 所有函数对象的proto都指向Function.prototype

  9. 所有的构造器都继承于 Function.prototype

二、理论与实践

1. 构造函数

构造函数官方定义未查看,通常申明构造函数时会将首字母大写。如下:

图1.png

变量person1与personl2 为构造函数Person创建的实例,故:

** person1.__proto__ === Person.prototype **

** person2.__proto__ === Person.prototyoe **

构造函数Person本质上由Function创建,即:

图2.png

故:Person.prototype.__proto__ === Function.prototype

图3.png

Person.prototype.constructor === Person

因为 typeof Function.prorotype === Object

所以Funtion.prototype是有Object生成的,即Funtion.prototype.__proto__ === Object.prototype

图4.png

注意:真正重要的点是,这个连接存在于实例(person1)与构造函数(Person)的原型对象(Person.prototype)之间,而不是存在于实例(person1)与构造函数(Person)之间。

2. 函数对象与普通对象

函数对象:js 自带的函数对象有Function,Object等,凡是通过new Function创建的对象统称为函数对象。

普通对象:我们常说的对象类型即为普通对象,比如同过对象自面量申明的变量

图5.png

o1 o2 o3为普通对象,f1 f2 f3 为函数对象


图6.png

如上图Function,Object,Array,String,Date等都为函数对象

3. 原型对象(prototype)与__proto__

原型和原型链是JS实现继承的一种模型,原型链的形成是真正是靠__proto__ 而非prototype。

图7.png

试题检测:


    var animal = function(){};

    var dog = function(){};

    animal.price = 2000;

    dog.prototype = animal;

    var tidy = new dog();

    console.log(dog.price)

    console.log(tidy.price)



    ```

相关文章

  • 廖雪峰JS小记

    (function(){})() 原型,原型链 浅谈Js原型的理解JS 原型与原型链终极详解 对象 对象:一种无序...

  • Javascript(三)之原型继承理解

    进阶路线 3 原型继承 3.1 优秀文章 最详尽的 JS 原型与原型链终极详解 一 最详尽的 JS 原型与原型链终...

  • js 原型与原型链小结

    一、基本理论 js 万物皆对象 对象分为函数对象与普通对象 每个函数都有一个prototype属性 每个对象都有一...

  • web前端面试之js继承与原型链(码动未来)

    web前端面试之js继承与原型链(码动未来) 3.2.1、JavaScript原型,原型链 ? 有什么特点? 每个...

  • JS原型链

    1什么是JS原型链? 通过__proto__属性将对象与原型对象进行连接. 1.1 JS原型链的作用? 组成的一个...

  • js_继承及原型链等(四)

    js_继承及原型链等(三) 1. 继承 依赖于原型链来完成的继承 发生在对象与对象之间 原型链,如下: ==原型链...

  • JavaScript 原型、原型链与原型继承

    原型,原型链与原型继承 用自己的方式理解原型,原型链和原型继承 javascript——原型与原型链 JavaSc...

  • JS的__proto__和prototype

    最近在回顾JS的原型和原型链的知识,熟悉JS的同学都知道JS的继承是靠原型链实现的,那跟原型链相关的属性__pro...

  • JS闭包问题(一)

    之前我写过一篇JavaScript原型与原型链的文章,此属于JS中的重难点。 而闭包,是JS中除了原型链之外又一个...

  • javascript中的原型链与继承

    javascript中的原型链与继承javascipt中的原型链和继承机制是这门语言所特有的,但js中的原型机制也...

网友评论

      本文标题:js 原型与原型链小结

      本文链接:https://www.haomeiwen.com/subject/rrgiectx.html