作用域概述
通常来说,一段程序代码中所用到的名字并不总是有效和可用的,而限定这个名字的可用性的代码范围就是这个名字的作用域。作用域的使用提高了程序逻辑的局部性,增强了程序的可靠性,减少了名字冲突。
全局作用域
作用于所有代码执行的环境(整个 script 标签内部)或者一个独立的 js 文件。
<script>
//2.js的作用域(es6之前)
//3.全局作用域: 整个script标签 或者是一个单独的js文件
</script>
局部作用域
作用于函数内的代码环境,就是局部作用域。 因为跟函数有关系,所以也称为函数作用域。
<script>
//4.局部作用域(函数作用域) 再函数内部就是局部作用域,这个代码的名字只在函数内部起作用
function fn() {
//局部作用域,与全局作用域互不影响
}
fn();
</script>
变量的作用域
在JavaScript中,根据作用域的不同,变量可以分为两种:全局变量和局部变量
全局变量
在全局作用域下声明的变量叫做全局变量(在函数外部定义的变量)。
<script>
var num = 10; //num是全局变量
</script>
小结
- 全局变量在代码的任何位置都可以使用
- 在全局作用域下 var 声明的变量 是全局变量
- 特殊情况下,在函数内不使用 var 声明的变量也是全局变量(不建议使用)
<script>
function fn() {
num = 20; //特殊情况:在函数中未声明就赋值的变量,作为全局变量
console.log(num);
}
fn(); //20
</script>
局部变量
<script>
function fn() {
var num = 20; //局部变量
console.log(num);
}
fn(); //20
</script>
小结
- 局部变量只能在该函数内部使用
- 在函数内部 var 声明的变量是局部变量
- 函数的形参实际上就是局部变量
作用域链
概述
只要是代码都一个作用域中,写在函数内部的局部作用域,未写在任何函数内部即在全局作用域中;如果函数中还有函数,那么在这个作用域中就又可以诞生一个作用域;根据在[内部函数可以访问外部函数变量]的这种机制,用链式查找决定哪些数据能被内部函数访问,就称作作用域链
注意点
作用域链:采取就近原则的方式来查找变量最终的值。