javascript 的作用域
1.执行环境
js的执行环境定义了变量或函数有权访问的其他数据,决定了它们各自的行为。每个执行环境都有一个与之关联的变量对象,环境中定义的所有变量和函数都保存在这个对象中。
每个函数都有自己的执行环境,当执行流程进入一个函数时,函数的环境就会被推入一个环境栈中。在执行完函数后,栈会将环境弹出,把控制权返回给之前的执行环境。
2.作用域(Scope)
简单来说,作用域就是变量与函数的可访问范围,即作用域控制着变量与函数的可见性和生命周期。js中的作用域分为两种:全局作用域和局部作用域
2.1全局作用域
全局变量的作用域是全局的:网页的所有脚本和函数都能访问它。一般有以下几种情形:
(1)在函数之外声明的变量
var name1 = "zhangsan" console.log(name1)//zhangsan function Fun(){ console.log(name1) } Fun()//zhangsan
(2)为尚未声明的变量赋值,此变量会自动成为全局变量(严格模式下不会自动创建全局变量)
function Fun(){ name1 = "zhangsan" var name2 = "lisi" } Fun() console.log(name1)//zhangsan console.log(name2)//报错
(3)所有window对象的属性拥有全局作用域
2.2局部作用域
局部变量的作用域是局部的:只能在函数内部访问它们。
例如上面的例子中,name2就是一个局部变量,只能在Fun()函数中访问,在函数外访问会报错。
3.作用域链
当代码在一个环境中执行时,会创建变量对象的一个作用域链。作用域链可以保证对执行环境有权访问的所有变量和函数的有序访问。
作用域链的前端始终是当前执行代码所在环境的变量对象。如果这个环境是函数,则将其活动对象作为变量对象。活动对象在最开始只包含一个arguments对象。
作用域链的下一个变量对象来自包含(外部)环境,再下一个变量对象则来自下一个包含环境,一直延续到全局执行环境。全局执行环境的对象始终是作用域链中的最后一个对象。
标识符解析会沿着作用域链一级一级地搜索标识符,注意,搜索始终是从作用域前端开始逐级向后回溯。