码迷,mamicode.com
首页 > Web开发 > 详细

关于JS原型以及原型链、instanceof的一些理解

时间:2019-09-20 18:29:59      阅读:95      评论:0      收藏:0      [点我收藏+]

标签:type   ons   bsp   span   说明   原型   str   就是   关于   

一、JS原型

首先要区分两个概念

1、构造函数

2、实例:由构造函数通过new方式创建出来的就是实例

    <script>
        function Foo() {

        }

        var f = new Foo();
        console.log(f instanceof Foo);
    </script>

比如上面这段代码,f是由new Foo()出来的,那么f称为Foo的实例,Foo也称为f实例的构造函数

1、每一个函数都有一个属性 prototype,这个属性也称该函数的显示原型,prototype是一个空的object对象

2、每一个实例都有一个属性 __proto__,这个属性也称这个实例的原型对象,也称隐式原型

3、实例的原型对象(隐式原型)等于该实例构造函数的显示原型

4、所有通过new Foo()创建出来的实例的__proto__都指向Foo.prototype,所以这些实例的__proto__都是同一个原型对象

这个用上面的代码来说明的话,那就是

    <script>
        function Foo() {

        }

        var f = new Foo();
        var k = new Foo();

        //f是Foo的实例
        console.log(f instanceof Foo); //true

        //3、实例的原型对象(隐式原型)等于该实例构造函数的显示原型
        console.log(f.__proto__ === Foo.prototype);//true

        //4、所有通过new Foo()创建出来的实例的__proto__都指向Foo.prototype,所以这些实例的__proto__都是同一个对象
        console.log(k.__proto__ === f.__proto__);//true
    </script>

  

二、原型链

当试图得到一个实例的某个属性时,如果这个实例本身没有这个属性,那么会去它的_proto_里去找。

    <script>
        function Foo() {
            this.age = 12;
        }
        Foo.prototype.name = "werben";

        var f = new Foo();
        
        //f这个实例本身有age属性,直接读取
        console.log(f.age); //output: 12
        
        //f这个实例本身没有name属性,那么会去它的_proto_里去找, 也就是Foo.prototype中去找name
        console.log(f.name); //output: werben
    </script>

  

 

 

关于JS原型以及原型链、instanceof的一些理解

标签:type   ons   bsp   span   说明   原型   str   就是   关于   

原文地址:https://www.cnblogs.com/werben/p/11558697.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!