深入理解函数内部原理(4)——通过new操作符调用构造函数

来源:互联网 发布:游戏键鼠套装推荐知乎 编辑:程序博客网 时间:2024/05/16 09:24

以new Experssion(args)
过程一:先确定是否是一个构造函数
先解析Experssion比姑且通过getValue方式取得该值F,通过判断这个值F是否是一个对象,并且这个对象F是否具有Construct内部方法,如果是的话证明是一个函数,否则抛出一个TypeError异常。

过程二:调用函数内部方法[Construct]
这个方法中分为如下几个过程:
(1)创建一个空的对象obj,然后添加一些通常的方法,将[Class]属性设置为“Object”
(2)通过F内部函数[Get]取F的prototype属性值proto,如果是一个对象的话,则将proto作为obj的[[Prototype]]值,否则将标准内置类型Object的原型值作为[[Prototype]]值
(3)将obj作为this,args作为参数调用F的[Call]方法,执行结果为result
(4)如果result为一个对象则返回,否则返回obj
所以,

        var o = {            "Fun":function(){                console.log(this === o);/*false*/            }        };var f = new o["Fun"]();
0 0