作用域与执行上下文的概念及区别

作用域与执行上下文的概念及区别

注意:本文旨在让大家了解二者的概念,并没有举出详细的例子,其它博客会有相关的例子,可以去参考

作用域

什么是作用域:作用域就是一个独立的地盘,让变量不会外泄、暴露出去。也就是说作用域最大的用处就是隔离变量,不同作用域下同名变量不会有冲突。
作用域的分类:常见的作用域主要分为几个类型:全局作用域、函数作用域、块状作用域、动态作用域(指的是call,aply等修改this指向)。
什么是作用域链作用域链:当我们想要访问某一个变量或者函数时,它回去当前作用于中去查找,如果当前作用域中没有,它就会去它父级作用域中查找,在没有就再向上找,如果一直没有找到就报错,我们把这种通过作用域采取链式查找的方式称为作用域链。

执行上下文

执行上下文的定义:执行上下文就是当前 JavaScript 代码被解析和执行时所在的环境, JavaScript 中运行任何的代码都是在执行上下文中运行。
执行上下文总共有三种类型:

  • 全局执行上下文
    这是默认的、最基础的执行上下文。不在任何函数中的代码都位于全局执行上下文中。它做了两件事:1.创建一个全局对象,在浏览器中这个全局对象就是 window 对象。2. 将 this指针指向这个全局对象。一个程序中只能存在一个全局执行上下文。
  • 函数执行上下文
    每次调用函数时,都会为该函数创建一个新的执行上下文。每个函数都拥有自己的执行上下文,但是只有在函数被调用的时候才会被创建。一个程序中可以存在任意数量的函数执行上下文。每当一个新的执行上下文被创建,它都会按照特定的顺序执行一系列步骤,具体过程将在本文后面讨论。
  • Eval 函数执行上下文
    运行在 eval 函数中的代码也获得了自己的执行上下文,但由于 Javascript 开发人员不常用 eval函数,所以在这里不再讨论。

两者的区别

作用域和执行上下文是两个不同的的概念
JavaScript 属于解释型语言,JavaScript 的执行分为:解释和执行两个阶段,这两个阶段所做的事并不一样:解释阶段:词法分析,语法分析,作用域规则确定。执行阶段:创建执行上下文,执行函数代码,垃圾回收。
他们最大的区别是:作用域在解释阶段确定的,并且不会改变;执行上下文在运行阶段确定的,随时可能改变。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

白嫖leader

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值