代码改变世界

区分词法作用域(js)与动态作用域(精!)

2017-04-14 12:45  心猿意‘码’  阅读(285)  评论(0编辑  收藏  举报

在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中并不具有动态作用域!!!