动态做用域让做用域做为一个在运行时就被动态肯定的形式, 而不是在写代码时进行静态肯定的形式。动态做用域并不关心函数和做用域是如何声明以及在何处声明的, 只关心它们从何处调用。 换句话说, 做用域链是基于调用栈的, 而不是代码中的做用域嵌套。javascript
词法做用域:java
function foo() { console.log( a ); // 2 } function bar() { var a = 3; foo(); } var a = 2; bar();
词法做用域让 foo() 中的 a 经过 RHS 引用到了全局做用域中的 a, 所以会输出 2。函数
动态做用域:this
function foo() { console.log( a ); // 3(不是 2 ! ) } function bar() { var a = 3; foo(); } var a = 2; bar();
事实上 JavaScript 并不具备动态做用域,它只有词法做用域 所以上述状况只有词法做用域是实际状况code
主要区别: 词法做用域是在写代码或者说定义时肯定的, 而动态做用域是在运行时肯定的。(this 也是! ) 词法做用域关注函数在何处声明, 而动态做用域关注函数从何处调用。ip