区分词法作用域(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)与动态作用域(精!)的主要内容,如果未能解决你的问题,请参考以下文章

你不知道的JS系列 ( 5 ) - 词法作用域

js的作用域

this的五种指法

我不知道的js作用域与闭包

JavaScript 作用域

JavaScript之静态作用域与动态作用域 #yyds干货盘点#