些全局变量分为两种:
一种是 ECMAScript 规定的,比如:global.parseInt,global.parseFloat,global.Number
一种是浏览器自己加的属性,比如:window.alert,window.prompt,window.comfirm
所有 API 都可以在 MDN 里找到详细的资料。这里我主要说的是第一种。
每当我们建一个新的对象时,我们似乎总是能用一大堆原先并没有定义的方法,这是为啥呢?因为有原型这个神奇的东西存在,每当我们申明的时候,他就会自动建立一个proto属性与所对应的方法的原型相连,这样我们就共用了原型的方法
简单的来说,我们要搞清楚原型链的架构,首先就要明白js的内置方法如何被构建起来的,由于js的垃圾回收机制,当一个对象未被引用的时候,就会被视作垃圾,于是就会被清除,但是我们发现Number,String这些方法都没有被清除,这就让人啧啧称奇了。这其实就是在每个对象内部加上了一个prototype属性,叫做该对象的原型属性,又给每个对象加上proto,叫做原型链指针,他指向本对象的原型对象,用这种方法使得每个对象相互连接。每当我们声明一个对象时,它就会去找到他所对应的方法的原型,然后予以连接,这也就能在建立一个对象以后,他能拥有许多你本身并没有定义的方法的原因,如图:
image.png此时,我声明了变量a,但是我并没有给a定义方法,但我toString却没有错,就是因为我的proto属性已经有了这个方法,所以不报错。
那么每个对象的原型链指针(proto)指向谁呢?内置对象的原型对象指向Function的原型,包括内置对象Function自己的,如图:
image.png但是,内置对象的原型对象(Function.prototype)的原型对象是谁呢?因为他本身就是个对象啊,于是他就指向对象的原型对象,于是
image.png也就是说,我们以后看见一个兑现,就判断他是属于啥方法,接着就归到啥方法的原型中去就好了
给出公式:
Object.proto === 对应方法的原型.prototype;
再举一个例子,还是那个空对象a,a的原型链指向应该是Object的原型,因为他就是Object方法构造出来的,而a.proto.proto(a的原型的原型链指向)就应该是null,因为他就是object.prototype.proto,值为null
image.png
网友评论