JS预编译

本文详细介绍了JavaScript中预编译的过程及其对函数执行顺序的影响,包括语法分析、预编译和解释执行三个阶段。重点讲解了函数声明的整体提升、变量声明的提升、暗示全局变量的概念及如何将声明的全局变量视为window属性。

弄懂预编译对于函数执行的顺序判断很重要

JS的运行三部曲

1.语法分析(也就是通篇扫描检查下是否有语法错误)

2.预编译

3.解释执行

预编译

1.首先对于预编译的两条抽象解释被用作方法(但是太复杂的语句没有办法解释,如函数名、参数名、变量名相同时)

(1)函数声明整体提升

无论函数声明放在哪里,在预编译时都会被整体提升至最开始。

例:text();

function  text();

在预编译时会把函数声明整体提升,所以text()不是未声明的,可以执行。

 

(2)变量   声明提升

变量的声明提升只提升声明,也就是说不会把后面的赋值也提升。

例:console.log(a);

var a=10;

结果为undefined

2.真正可以解决复杂问题的两条办法

(1)imply global(暗示全局变量):任何变量,如果变量未经声明就赋值,此变量就为全局对象所有。

(2)一切声明的全局变量,全是window的属性

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

 

预编译的四个步骤:

1.创建AO(函数作用域对象)对象

2.找形参和变量声明,将变量和形参名作为AO属性名,值为undefined

3.将实参值和形参统一

4.在函数体里面找函数声明,值赋予函数体

例题:

1.

function bar(){

        return foo;

        foo = 10;

        function foo(){

 

}

        var foo = 11;

}

console.log(bar());---------------->function foo()

 

2.

console.log(bar());----------------->11

function bar(){

        foo = 10;

        function foo(){

 

}

        var foo = 11;

        return foo;

}

 

补充:

(Global Object)GO===window,先AO再GO

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值