# 词法作用域和动态作用域
作用域规定了如何查找变量,也就是确定当前执行代码对变量的访问权限。
因为 JavaScript 采用的是词法作用域,函数的作用域在函数定义的时候就决定了。也就是静态作用域
而与词法作用域相对的是动态作用域,函数的作用域是在函数调用的时候才决定的。
var value = 1;
function foo() {
console.log(value);
}
function bar() {
var value = 2;
foo();
}
bar();
// 1
// 执行 foo 函数,先从 foo 函数内部查找是否有局部变量 value,如果没有,就根据书写的位置,查找上面一层的代码,也就是 value 等于 1,所以结果会打印 1。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
var scope = "global scope";
function checkscope() {
var scope = "local scope";
function f() {
return scope;
}
return f()
}
checkscope();
var scope = "global scope";
function checkscope() {
var scope = "local scope";
function f() {
return scope;
}
return f;
}
checkscope()();
都返回 local scope。 两者的区别是什么?
<!--下边是闭包,上边是函数执行 -->
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21