作用域
作用域是在运行时代码中的某些特定部分中变量,函数和对象的可访问性。换句话说,作用域决定了代码区块中变量和其他资源的可见性。
分为全局作用域和局部作用域(函数作用域、块级作用域)
内层作用域可以访问外层作用域的变量,反之则不行。
全局作用域
若变量在函数内部没有声明(未使用var关键字),该变量为全局变量,全局变量在页面关闭后销毁
以下几种情形拥有全局作用域
- 最外层函数和最外层函数外面定义的变量拥有全局作用域
- 所有未定义直接赋值的变量,拥有全局作用域
- 所有window对象的属性拥有全局作用域
函数作用域
定义在函数体内的变量或者函数都将处于函数作用域中,这些变量无法被函数外部使用
局部变量在函数开始执行时创建,函数执行完后,局部变量会自动销毁
值得注意的是:块语句(大括号“{}”中间的语句),如 if 和 switch 条件语句或 for 和 while 循环语句,不像函数,它们不会创建一个新的作用域。在块语句中定义的变量将保留在它们已经存在的作用域中。
if (true) {
// 'if' 条件语句块不会创建一个新的作用域
var name = 'Hammad'; // name 依然在全局作用域中
}
console.log(name); // logs 'Hammad'
块级作用域
是ES6提出的
可通过新增命令let和const声明,所声明的变量在指定块的作用域外无法被访问。块级作用域在如下情况下被创建:
1.在一个函数内部
2.在一个代码块中(由一对花括号囊括)内部
块级作用域有以下一个特点:
- 声明的变量不会提升到代码块顶部
- 禁止重复声明
作用域链
出现嵌套函数,就会出现作用域链
引擎从当前的执行作用域开始查找变量,如果找不到,就向上一级继续查找,当抵达最外层全局作用域时,无论是否找到,查找过程都会停止,就形成了作用域链
简单来说,局部作用域可以访问到全局作用域中的变量和方法,但是全局作用域不可以访问局部作用域的变量和方法