注意:本文旨在让大家了解二者的概念,并没有举出详细的例子,其它博客会有相关的例子,可以去参考
作用域
什么是作用域:作用域就是一个独立的地盘,让变量不会外泄、暴露出去。也就是说作用域最大的用处就是隔离变量,不同作用域下同名变量不会有冲突。
作用域的分类:常见的作用域主要分为几个类型:全局作用域、函数作用域、块状作用域、动态作用域(指的是call,aply等修改this指向)。
什么是作用域链作用域链:当我们想要访问某一个变量或者函数时,它回去当前作用于中去查找,如果当前作用域中没有,它就会去它父级作用域中查找,在没有就再向上找,如果一直没有找到就报错,我们把这种通过作用域采取链式查找的方式称为作用域链。
执行上下文
执行上下文的定义:执行上下文就是当前 JavaScript 代码被解析和执行时所在的环境, JavaScript 中运行任何的代码都是在执行上下文中运行。
执行上下文总共有三种类型:
- 全局执行上下文:
这是默认的、最基础的执行上下文。不在任何函数中的代码都位于全局执行上下文中。它做了两件事:1.创建一个全局对象,在浏览器中这个全局对象就是 window 对象。2. 将 this指针指向这个全局对象。一个程序中只能存在一个全局执行上下文。 - 函数执行上下文:
每次调用函数时,都会为该函数创建一个新的执行上下文。每个函数都拥有自己的执行上下文,但是只有在函数被调用的时候才会被创建。一个程序中可以存在任意数量的函数执行上下文。每当一个新的执行上下文被创建,它都会按照特定的顺序执行一系列步骤,具体过程将在本文后面讨论。 - Eval 函数执行上下文:
运行在 eval 函数中的代码也获得了自己的执行上下文,但由于 Javascript 开发人员不常用 eval函数,所以在这里不再讨论。
两者的区别
作用域和执行上下文是两个不同的的概念
JavaScript 属于解释型语言,JavaScript 的执行分为:解释和执行两个阶段,这两个阶段所做的事并不一样:解释阶段:词法分析,语法分析,作用域规则确定。执行阶段:创建执行上下文,执行函数代码,垃圾回收。
他们最大的区别是:作用域在解释阶段确定的,并且不会改变;执行上下文在运行阶段确定的,随时可能改变。