美文网首页我爱编程
JS 我理解的原型与原型链

JS 我理解的原型与原型链

作者: bzwhlll | 来源:发表于2018-05-28 16:17 被阅读0次

    Browser中的对象

    浏览器中有哪些对象?ES中规定全局对象为global,而浏览器中规定全局对象为window。

    在chrome控制台中输入window,我们就能看到window里有哪些内容。

    下面的这些对象在window里都能找到。
    如Object,Sring,Numbr,Boolean,Array,Date,Math,parseInt, parseFloat这些属性都是ES规定的必须有的对象。
    如doucument,alert,prompt,atob等这些是浏览器中内置的属性。

    这些对象都具有hash结构,如Object下,String下都有自己的属性和方法,都有相应的API调用。

    简单类型和对象

    例子如下:n1是简单类型,n2是对象。

    var n1 = 'a'
    var n2 = new String('a')
    n1.length
    n1.hasOwnProperty('0')
    n2.length
    n2.hasOwnProperty('0')
    n1.xxx = 2
    n1.xxx // undefined
    

    区别

    n1值是存储在stack中。n2赋值时,stack中建立一个地址,指向heap中,堆内存中新建了一个String类型的对象。能看到对象n2里有一些属性,还有prototype属性。

    属性

    n2是对象,里面有length属性,所以调用。n1只是字符串,为何也有length属性

    可以这样理解:n1.length时,这时js会进行如下操作:var temp = new String(n1);n1.length;也就是使用属性,或方法时,会临时的在堆内存中新建一个对象,这个对象是相应的String类型,执行后,temp便被销毁。因此n1.xxx = 2操作不会报错,而再次n1.xxx显示undefined,因为此时n1在堆内存中的数据已经销毁了。

    因此,js中,很少使用new一个新对象的方法,而是直接对变量进行赋值。

    n2中的hasOwnProperty()

    hasOwnProperty()是Object类型中的方法,Sting类型下并没有找到它,在哪找到它?

    这里hasOwnProperty()是在n2.__proto__.__proto__里面。n2.__proto__指向的是String.prototype,而String.prototype.__proto__最后指向Object.prototype。String是一种原型,Object也是一种原型。Object.prototype中存放了所有Object类型的公共属性

    以这种方式,能有效的节省空间,避免每个对象里面都记录很多的属性,一个object里没有的属性,就到__proto__指向的对象里面寻找。而指向的地方通常是某个原型的prototype。

    去哪里找 __proto__和prototype

    var n = new Number(1)
    var s= new String('1')
    var o= new Object()
    

    以上几种方式都能看成 var 对象 = 函数()的形式。
    归纳出,对象.__proto__ =函数.prototype。

    访问 __proto__

    __proto__是相对于对象来说,找爸爸,看是谁生成的对象。对n来说,爸爸是Number,就去Number.prototype里面寻找。Number里也有__proto__,访问时,到它的爸爸Object里面寻找。

    prototype.png

    上图中,每个方框代表一个对象,存放在堆内存(heap)中的一块区域。

    Function

    String.__proto__ === Function.prototype //true
    

    函数也能看作是对象,String,Object,Number都是对象,也都是函数。因为之前用到了new String(),所以这是函数,函数return结果的数据类型为object。String的爸爸便是Function。

    Function.__proto__ === Function.prototype //true
    Function.prototype.__proto__ === Object.prototype //true
    Function.__proto__.__proto__ === Object.prototype //true
    

    当把函数Function看作是由Function方法生成的对象时,
    即var Function = new Function()
    便能理解 Function.__proto__ === Function.prototype

    Function.png
    上图中,Fuction的类型是function,它是由Function构造出来的。关系从上图可以看出来。new String()时,String的类型也是function,String.__proto__指向的就是Function.prototype

    相关文章

      网友评论

        本文标题:JS 我理解的原型与原型链

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