■ 关于作用域
通常来说,一段程序代码中所用到的名字并不总是有效和可用的
而限定这个名字的可用性的代码范围就是这个名字的作用域
通俗讲,作用域就是代码名字(变量)在某个范围内起作用和效果,目的是为了提高程序的可靠性,更重要的是减少命名冲突
■ 全局作用域和局部作用域
全局作用域
全局作用域,就是整个
例:
var num = 10; //全局有效
function fun() {
var num = 20; //局部有效
}
■ 变量的作用域
根据作用域的不同,变量可以分为以下:
- 全局变量
在全局作用域下声明的变量(在函数外部定义的变量)
全局变量在代码的任何位置都可以使用
全局变量只有在浏览器关闭时,才会销毁,比较占内存资源
注意: 如果在函数内部,没有声明直接赋值的变量也属于全局变量 - 局部变量
在局部作用域下声明的变量(在函数内部定义的变量)
函数内部的变量就是局部变量,只能在函数内部使用
局部变量当程序执行完毕,就会销毁,比较节约内存资源
注意: 函数的形参,可以看做一个局部变量
■ 块级作用域
es6及以后,js没有块级作用域
if(3 < 5) {
var num = 10;
}
console.log(num); //输出:10
■ 作用域链
只要是代码,就有一个作用域
如果函数中还有函数,那么在这个作用域中就又可以诞生一个作用域
根据内部函数可以访问外部函数变量的这种机制,用链式查找决定哪些数据能被内部函数访问,就称为作用域链
内部函数访问外部函数的变量,采用的是链式查找的方式来决定取哪个值,这种结构被称为作用域链
就是一层一层网上找,采用就近原则
var num = 10; //全局变量
fn() {
var num = 20; //局部变量
function fun(){ //内部函数
console.log(num); //输出:20
}
fun(); //调用内部函数
}
fn(); //调用外部函数