Web前端:JavaScript基础篇之执行上下文与作用域

首先需要明确的是执行上下文作用域是两个不同的概念,很多人都将其混淆在了一起。

上下文的概念其实在JavaScript中还是很重要的。变量或函数的上下文决定了它们可以访问那些数据,以及他们的行为。

每个上下文都有一个关联的变量对象,儿这个上下文中定义的所有的变量和函数都存于这个对象上。

注:这个变量对象无法通过代码访问,但后台处理数据的时候会用到它。

全局上下文就是最外层的上下文。根据实现的宿主环境,不同,表示全局上下文的对象可能不同,通常在浏览器中,全局上下文就是我们所说的window对象(后期会出),因此通过var定义的全局变量和函数都会成为对象的属性和方法。但是使用let和const的顶级声明不会定义在全局上下文中。但在作用域链解析上效果是一样的。 上下文在其所有代码都执行完毕后会被销毁。包括定义在它上面的所有变量和函数(全局上下文在应用程序退出前才会被销毁,比如关闭网页或退出刘览器)。

每个函数调用都有自己的上下文。当代码执行流进入函数时,函数的上下文被推到一个上下文栈上。在函数执行完之后,上下文栈会弹出该函数上下文,将控制权返还给之前的执行上下文,程序的执行流就是通过这个上下文栈来进行控制的。

上下文中的代码在执行的时候,会创建变量对象的一个作用域链。这个作用域链决定了各级上下文中的代码在访问变量和函数时的顺序。代码正在执行的上下文的变量对象始终位于作用域链的最前端。如果上下文是函数,则其活动对象用作变量对象。活动对象最初只有一个定变量:arguments (全局上下文中没有这个变量。)作用城链中的下一个变量对象来自包含上下文,再下一个对象来自再下一个包含上下文。 以此类推直至全局上下文;全局上下文的变量对象始终是作用链的最后一个对象。

代码执行时的标识符解析是通过沿作用域链逐级搜索标识符名称完成的。搜索过程始终从作用域链的最前端开始,然后逐级往后,直到找到标识符。(如果没有找到标识符,那么通常会报错。)

例:

        var age = 15;

        function fun(){

         

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值