
这个题设涉及预编译和一些零碎的知识点。
1、生成全局对象GO
2、寻找变量声明 GO={ foo:undefined }
3、寻找函数声明 GO={ foo:undefined , 匿名:function(){} }
4、执行 foo={ n:1 }
5、执行匿名函数前先生成活动对象AO
6、寻找形参和变量声明 AO={ foo:undefined }var foo声明提前,给一个已声明且赋值的变量再次声明是没有意义的,还是原值。
7、将形参赋予实参 AO={ foo: {n:1} }
8、寻找函数声明 ------- 无
9、执行 console.log(foo.n) ------ 输出 1
10、执行 foo.n=3 只是修改了n的值,foo的指向没变
11、执行 foo={ n:2 } foo指向新的对象
12、执行console.log(foo.n) ------ 输出 2
13、匿名函数里的foo的生命周期仅在该函数内,函数执行完销毁
14、执行console.log(foo.n) ------ 输出 3
函数传参(引用类型的参数)传的是值,地址值,在函数内部的改动虽然能影响外部,但外部变量的指向没变,依然指向原地址。
JS作用域与生命周期解析
本文深入探讨JavaScript中预编译过程,详细分析全局对象生成、变量与函数声明、执行上下文创建及生命周期管理。通过具体示例,阐述变量声明提升、函数参数传递机制以及引用类型变量在函数内外部的指向变化。
1005

被折叠的 条评论
为什么被折叠?



