区分词法作用域(js)与动态作用域(精!)
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了区分词法作用域(js)与动态作用域(精!)相关的知识,希望对你有一定的参考价值。
在js学习中,词法作用域是必须要掌握的!
在这里,我将总结一下《你不知道的JS》一书中词法作用域的重点并分享给大家!
首先带来一段代码示例:
function foo(){ console.log(a);//2 } function bar(){ var a = 3; foo(); } var a = 2; bar();
js词法作用域输出结果:"2"; 动态作用域输出结果:"3"
下面我将对两种作用域的输出结果进行分析:
#在对结果分析之前首先我们要了解的是:词法作用域关注函数在何处声明,而动态作用域关注函数从何处调用
##词法作用域代码解析:bar() 会调用 foo(),foo() 再查询所需变量,因为函数是在foo处声明的,所以会从foo所在作用域进行查找,所得结果为"2";
##动态作用域代码解析:由于函数是从 bar()开始调用的,因此会从 bar()所在作用域查找变量,因此按照动态作用域的运行结果得到的结果是"3".
#最后要强调的一点:在JS中并不具有动态作用域!!!
以上是关于区分词法作用域(js)与动态作用域(精!)的主要内容,如果未能解决你的问题,请参考以下文章