解读预编译

解读预编译

预编译发生在函数执行的前一刻


  • JavaScript在执行的过程分为三个步骤 :

    1. 语法分析,找出低级错误
    2. 预编译(函数声明整体提升,变量声明提升)
    3. 解释执行

    预编译的过程是在内存中开辟一些空间,存放一些变量与函数,系统自动将函数的声明提到最前,而对于变量只将声明提前,对赋值操作不做处理(如果变量声明赋值为一步的话则将生命和赋值拆开

    imply global指暗示全局变量:即任何变量如果未经声明就赋值,此变量即为全局对象所有,一切声明的全局变量都是window的属性,window是全局的域

    var a = 123; → window.a=123; 


    预编译四部曲
    1. 创建AO对象(Activation Object执行期上下文)
    2. 找形参和变量声明,将变量和形参名作为AO属性名,值初始化为undefined;
    3. 将形参值和实参值相统一,用实参值代替掉3中的形参值;
    4. 在函数里找函数声明,值赋予函数体。
       <code><pre> function test()
        {
            console.log(a);     //function a(){}
            console.log(b);     //undefined
            var b = 234;
            console.log(b);     //234
            a = 123;
            console.log(a);     //123
            function a(){}
            var a;
            b = 234;
            var b = function(){}
            console.log(a);     //123
            console.log(b);     //f(){}
        }       
        test(1);</pre></code>
       <p>存在全局变量时预编译过程变化不大</p>
    
    1. 创建GO对象(GO(Golobal Objective)
    2. 找形参变量声明
    3. 在函数里找函数声明,值给函数名。
       <code><pre>
            console.log(bar());    //11
            function bar()
        {
            foo=10;
            function foo(){
            }
            var foo = 11;
            return foo;
        }
            a = 100;
            function demo(e){
            function e(){}
            arguments[0]=2;
            document.write(e)     //2
            if(a){
                var b=123;
                function c(){
    
                }
            }
            var c;
            a = 10;
            var a;
            document.write(b)     //undefind
            f = 123;
            document.write(c);    //undefined
            document.write(a);    //10
        }
            var a;
            demo(1);
            document.write(a);    //100
            document.write(f);    //123
        </pre><code>
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值