javascript没有块级作用域,只有函数作用域。javascript代码执行过程中,第一个进入的默认是全局作用域,执行函数的时候会进入该函数的作用域。
函数是Function对象的一个实例,拥有可以编程访问的属性,和一些不能通过代码访问而仅供javascript引擎存取的内部属性。今天要介绍的就是Scope这一内部属性。
在javascript中每一个函数,都有一个scope属性,scope属性的值是一个链表,即该函数的作用域链。
用下面这段代码举例
function test(){
var a=4;
var b=2;
console.log(a+b);
}
test();当函数被创建时,作用域链的第一个节点就有了,即全局对象,该对象包含诸如this,window,document等全局作用域中的变量。

当函数被执行时,作用域链的原第一个节点,即全局对象,变成第二个节点,新的第一个节点是,活动对象即执行环境(执行上下文),这个对象中包含当前执行函数的变量,参数,this。这些值按照它们出现在函数中的顺序,排列在活动对象内。

注意函数每次执行时对应的执行环境是独一无二的,所以多次调用同一函数会创建多个执行环境。当函数执行完毕,执行环境就被销毁。
众所周知,当函数在内部遇到一个变量,它会先找一找函数内部有没有这个变量的值,如果没有就到上一层去找一找,直到找到全局作用域。这是因为,标识符解析过程,是从作用域链这个链表的头部开始向尾部查找的。头部是该函数作用域,尾部自然是全局作用域。
本文深入探讨了JavaScript中的作用域概念,解释了函数作用域而非块级作用域的特点,并通过示例详细介绍了作用域链的工作原理及其如何帮助解析变量。
826

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



