关于JS中的自由变量与作用域链

自由变量

在A作用域中使用的变量x,却没有在A作用域中声明(即是在其他作用域中声明的),对于A作用域来说,x就是一个自由变量
在这里插入图片描述

作用域链

先说一说什么是作用域链呢?

当代码在一个环境中执行时,会创建变量对象的一个作用域链(作用域形成的链条)

1、作用域链的前端,始终都是当前执行的代码所在环境的变量对象
2、作用域链中的下一个对象来自于外部环境,而下一个变量对象则来自于下一个外部环境,一直到全局执行环境
3、全局执行环境的变量对象始终都是作用域链上的最后一个对象

内部环境可以通过作用域链访问所有外部环境,但外部环境不能访问内部环境的任何变量和函数。

当在内部函数中,需要访问一个变量的时候,首先会访问函数本身的变量对象,是否有这个变量,如果没有,那么会继续沿作用域链往上查找,直到全局作用域。如果在某个变量对象中找到则使用该变量对象中的变量值。

我们看下面的代码:

var x = 10;
function fn() {
    console.log(x);
}

function show(f) {
    var x = 20;
        (function () {
            f()  //输出10
        })()
}

show(fn)  

从上面的代码中我们可以发现,

要到创建这个函数的那个作用域中取值(是创建而不是调用),其实这就是所谓的“静态作用域”。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值