枯燥的js预编译。

js运行三部曲
语法分析
预编译
解释执行

函数声明整体提升
不管函数写在调用之前还是之后,都会先将函数放在最前面。

变量 声明提升
var a =123;
在预编译中会变成,var a; a=123;
var a;会放在最前面,但变量没有值,为undefined

预编译前奏
1.imply global 暗示全局变量:即任何变量,如果变量未经声明就赋值,此变量就为全局变量所有。
eg:
a = 100;
此时windo.a=100;
全局对象 :window(全局的域)
2.一切声明的全局变量,全是window的属性。
eg:var a =100;window.a = 100;
简而言之,没有声明的变量和声明了的全局变量都会放在window这个域里面。

函数预编译四部曲
1.创建AO对象(Activation Object 执行期上下文)
2.找形参和变量声明,将变量和形参名作为AO属性名,值为undefined
3.将实参值和形参统一。
4.在函数体里面找函数声明,值赋予函数体。

全局预编译
1.生成一个GO对象 Global Object
GO ===window
除了第三条没有其余一样。

eg:

function test(){
    
    
	var a = b = 123;
	console.log(b);
}
test ();

此时b为未声明变量,放在GO中,
GO{
b :123
}
又因为GO===window,所以此时console.log(b);有值。console.log(a);没有值。

AO与GO的优先级
函数里面先是在AO里面找,然后再是GO里面。(链式关系)

猜你喜欢

转载自blog.csdn.net/weixin_51664705/article/details/113619944