首页 > Web开发 > 详细

js 词法作用域揭秘

时间:2018-11-05 23:30:40      阅读:282      评论:0      收藏:0      [点我收藏+]

先看段代码:

//词法作用域
var scope = "global";
function fn1(){
    console.log(scope);
}
function fn2(){
    var scope = "local";
    fn1();
}
fn2();    

结果是global

为什么呢?

js是采用词法作用域,即静态作用域。

JavaScript 函数的执行用到了作用域链,这个作用域链是在函数定义的时候创建的。fn1调用fn2,fn2 的作用域链按照书写的位置查找,其中的变量 scope 一定是全部变量,不管何时何地执行函数 fn1(),打印的都是全局的“global”。

 

js 词法作用域揭秘

原文:https://www.cnblogs.com/amy2017/p/9912168.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!