首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JS 执行上下文

JavaScript执行环境 全局环境 函数环境 eval函数环境 (已不推荐使用) 那么与之对应执行上下文类型同样有3种: 执行上下文类型 全局执行上下文 函数执行上下文 eval函数执行上下文...程序代码基本都会存在函数,那么调用函数,就会进入函数执行环境,对应就会生成该函数执行上下文。 先插播一个知识点:JS是"单线程"! "单线程"! "单线程"!...JS管理多个执行上下文 函数编程,代码中会声明多个函数,对应执行上下文也会存在多个。...程序执行进入一个执行环境时,它执行上下文就会被创建,并被推入执行(入栈);程序执行完成时,它执行上下文就会被销毁,并从栈顶被推出(出栈),控制权交由下一个执行上下文。...因为JS执行中最先进入全局环境,所以处于"栈底永远是全局环境执行上下文"。

4.1K41

如何理解js执行上下文执行

执行上下文执行栈是js执行机制两个概念,要想深入js进行理解与应用,理解js机制很重要,下面来说一下什么是执行上下文,什么又是执行栈。...执行上下文 简而言之,执行上下文就是当前 JavaScript 代码被解析和执行时所在环境抽象概念, JavaScript 运行任何代码都是在执行上下文中运行。...一个程序只能存在一个全局执行上下文。 函数执行上下文是指在每次调用函数时,都会为该函数创建一个新执行上下文,这就是函数执行上下文,他可以有无数个。有多少个函数就有多少个函数执行上下文。...每个函数都拥有自己执行上下文,但是只有在函数被调用时候才会被创建。一个程序可以存在任意数量函数执行上下文。每当一个新执行上下文被创建,它都会按照特定顺序执行一系列步骤。...Eval 函数执行上下文:是指运行在 eval 函数代码创建自己执行上下文

1.7K20
您找到你想要的搜索结果了吗?
是的
没有找到

JS学习系列 05 - 执行上下文

定义 当 JS 引擎开始执行预编译生成代码时,就会进入到一个执行上下文(Executable Code - 简称 EC)。...可执行代码有几种 前面说到当引擎执行到可执行代码时候,就会将当前上下文压入上下文。那么可执行代码又分为几种?...在这里,我们先假设定义执行上下文栈是一个数组: EC = []; 第一种可执行代码 -- 全局代码: 全局类型代码是在加载外部 js 文件或者本地 标签代码。...程序启动后进入初始化全局环境: EC = [ globalContext ]; 第二种可执行代码 -- 函数代码: 当定义函数被执行时,就进入了函数代码,当前函数上下文被压入 EC 栈。...当所有代码执行完以后,EC 只会包含全局上下文(global context),当程序退出以后,全局上下文也会退出。

8010

JS面试点-执行上下文详解

执行 JS 代码时,会产生三种执行上下文 全局执行上下文 函数执行上下文 eval 执行上下文 每个执行上下文中都有三个重要属性 变量对象(VO),包含变量、函数声明和函数形参,该属性只能在全局上下文中访问...作用域链(JS 采用词法作用域,也就是说变量作用域是在定义时就决定了) this var a = 10 function foo(i) { var b = 20 } foo() 对于上述代码,执行栈中有两个上下文...通常提升解释是说将声明代码移动到了顶部,这其实没有什么错误,便于大家理解。但是更准确解释应该是:在生成执行上下文时,会有两个阶段。...第一个阶段是创建阶段(具体步骤是创建 VO),JS 解释器会找出需要提升变量和函数,并且给他们提前在内存开辟好空间,函数的话会将整个函数存入内存,变量只声明并且赋值为 undefined,所以在第二个阶段...() { foo = 10 ; console.log(foo) } 因为当 JS 解释器在遇到非匿名立即执行函数时,会创建一个辅助特定对象,然后将函数名称作为这个对象属性,因此函数内部才可以访问到

88820

JS学习系列 05 - 执行上下文

定义 当 JS 引擎开始执行预编译生成代码时,就会进入到一个执行上下文(Executable Code - 简称 EC)。...栈底部永远是全局上下文(global context),而顶部就是当前活动执行上下文执行到当前代码时,上下文入栈,执行完毕后,上下文出栈。 2....可执行代码有几种 前面说到当引擎执行到可执行代码时候,就会将当前上下文压入上下文。那么可执行代码又分为几种?...在这里,我们先假设定义执行上下文栈是一个数组: EC = []; 复制代码 第一种可执行代码 -- 全局代码: 全局类型代码是在加载外部 js 文件或者本地 标签代码。...当所有代码执行完以后,EC 只会包含全局上下文(global context),当程序退出以后,全局上下文也会退出。

95330

JS执行上下文与调用栈

执行上下文类型 JavaScript 中有三种执行上下文类型。 全局执行上下文 — 这是默认或者说基础上下文,任何不在函数内部代码都在全局上下文中。...它会执行两件事:创建一个全局 window 对象(浏览器情况下),并且设置 this 值等于这个全局对象。一个程序只会有一个全局执行上下文。...调用栈列表: - greeting 10.当 greeting() 函数所有内容都执行完之后,返回到它调用行继续执行其余JS代码。 11.把 greeting() 方法从调用栈列表删除。...调用栈列表: 空 我们从一个空调用栈开始,当我们调用一个函数时,它会自动添加到调用栈,在执行完所有代码之后,它会自动从调用栈删除。最后,我们也得到了一个空栈。 怎么创建执行上下文?...(在浏览器, this引用 Window 对象)。 在函数执行上下文中, this 值取决于该函数是如何被调用

1.5K10

JS the Hardcore: 执行上下文(Execution Context)

类似,EC 就是一段代码涉及到场景,在代码运行之前,js engine 会做一些变量内存分配,代码上下文关联准备工作,这就是 EC。...EC 中会给变量分配一个存储空间,与之对应数据结构称作 enviroment。 当程序流程需要从当前 EC 进入另外一个和当前上下文无关代码片段时,会创建一个新 EC,并被推入栈。...这就是「执行上下文栈」(Execution Context Stack),可以看作是 调用栈镜像。...由于所有的 js 代码都存在于全局环境,所以首先会创建 「全局执行上下文」(Global Execution Context),除此之外,js 每一次函数调用也会生成 EC,所以栈底肯定会是 全局执行上下文...代码执行到 ln 09 时,因为是对函数调用,会创建一个新执行上下文,并置为「当前执行上下文」: foo Execution Context = { this: window,

99470

JS词法环境和执行上下文

代码都是在执行上下文中运行。你可以将代码运行与执行上下文关系类比为进程与内存关系,在代码运行过程变量环境信息都放在执行上下文中,当代码运行结束,执行上下文也会销毁。...在执行上下文中记录了代码执行过程状态信息,根据不同运行场景,执行上下文会细分为如下几种类型:全局执行上下文:当运行代码是处于全局作用域内,则会生成全局执行上下文,这也是程序最基础执行上下文。...而执行栈(Execution Context Stack)是用来管理执行期间创建所有执行上下文数据结构,它是一个LIFO(后进先出)栈,它也是我们熟知JS程序运行过程调用栈。...将全局执行上下文压入执行栈,通常JS引擎都有一个指针running指向栈顶元素:图片JS引擎会将全局范围内声明函数(foo)初始化在全局上下文中,之后开始一行行执行代码,运行到console就在running...总结本文关于执行上下文理论知识比较多,不容易马上吸收理解,建议你逐渐消化、反复阅读理解。当你熟悉了执行上下文和词法环境,相信去理解认识更多JS特性和概念时,会更加轻松容易。

1.3K30

理解JavaScript 执行上下文执行

执行上下文类型 执行上下文总共有三种类型 全局执行上下文:只有一个,浏览器全局对象就是 window 对象,this 指向这个全局对象。...函数执行上下文:存在无数个,只有在函数被调用时候才会被创建,每次调用函数都会创建一个新执行上下文。 Eval 函数执行上下文: 指的是运行在 eval 函数代码,不用很少用而且不建议使用。...执行执行栈,也叫调用栈,具有 LIFO(后进先出)结构,用于存储在代码执行期间创建所有执行上下文。 首次运行JS代码时,会创建一个全局执行上下文并Push到当前执行。...根据执行栈LIFO规则,当栈顶函数运行完成后,其对应函数执行上下文将会从执行Pop出,上下文控制权将移到当前执行下一个执行上下文。...执行上下文创建 执行上下文分两个阶段创建:1)创建阶段; 2)执行阶段 创建阶段 1、确定 this 值,也被称为 This Binding。

37630

理解JavaScript 执行上下文执行

执行上下文总共有三种类型 全局执行上下文:只有一个,浏览器全局对象就是 window 对象,this 指向这个全局对象。...函数执行上下文:存在无数个,只有在函数被调用时候才会被创建,每次调用函数都会创建一个新执行上下文。...Eval 函数执行上下文: 指的是运行在 eval 函数代码,不用很少用而且不建议使用。...执行执行栈,也叫调用栈,具有 LIFO(后进先出)结构,用于存储在代码执行期间创建所有执行上下文。 首次运行JS代码时,会创建一个全局执行上下文并Push到当前执行。...根据执行栈LIFO规则,当栈顶函数运行完成后,其对应函数执行上下文将会从执行Pop出,上下文控制权将移到当前执行下一个执行上下文。 ?

58720

稳扎稳打JS——执行上下文

上下文环境初始化在代码执行前完成 JS有三种作用域:全局作用域、函数作用域、eval作用域(不常用,不做介绍)。...在JS代码执行前,首先会对这三种作用域进行上下文环境准备工作,准备内容如下: 全局作用域上下文准备工作 将全局变量设为undefined 将函数表达式值设为undefined 为函数声明直接赋值...JS运行时才能确定,而全局作用域中this在准备上下文环境时候就确定了(window)。...因为在代码运行前准备上下文环境过程,函数初始化已经完成,所以运行时无论函数调用语句在哪儿,JS编译器都能调用这个函数。 若采用函数表达式来定义函数,则函数定义一定要在函数调用语句之前!...JS作用域只有三种:全局作用域、函数作用域、eval作用域。除此之外就没有作用域了!如:for、if、while等都不是独立作用域! 因此在里面定义局部变量都属于其所属外层作用域。

1.1K70

JS执行上下文作用域闭包

一、执行上下文 单线程 同步执行,只有栈顶上下文处于执行,其他上下文需要等待 全局上下文只有唯一一个,它在浏览器关闭时出栈 函数执行上下文个数没有限制 每次某个函数被调用,就会有个新执行上下文为其创建...,即使是调用自身函数,也是如此。...—— return 2、函数作用域 js没有块级作用域,而有函数作用域。 函数作用域是指:在函数内声明所有变量在函数体内是始终可见。...---- 四、this 全局函数里,this 等于window 函数被作为某个对象方法调用时,this等于那个对象 匿名函数执行环境具有全局性,this指向window (可以通过call()或apply...()改变函数执行环境)

1.2K30

【说站】Js如何存储执行上下文

Js如何存储执行上下文 1、执行上下文存在于数据栈。该栈保存代码运行是创建所有上下文。 栈特点是后进先出,每创建一个新上下文,就会压入栈顶部。...当函数执行完成时,上下文从栈中弹出,控制过程到达栈下一个上下文。 2、当js引擎第一次触摸脚本时,它将创建一个全局上下文,并将其压入栈。...,入上下文执行栈 同理   F2(name);     //F2 出栈   console.log(sex); //sex未创建,未赋值,且作用域链也没有,所以报错 sex not defined }...// 创建F1上下文,入上下文执行栈 F1(); // F1出栈 // 全局上下文出栈 以上就是Js存储执行上下文方法,希望对大家有所帮助。...更多js学习指路:js教程 收藏 | 0点赞 | 0打赏

96130

JavaScript执行上下文和堆栈

first-article 在这篇文章,我将深入探讨JavaScript最基本部分之一,即Execution Context(执行上下文)。...Execution Context Stack(执行上下文堆栈) 浏览器JavaScript解释器被实现为单个线程。...如果在全局代码调用函数,程序顺序流进入被调用函数,创建新执行上下文并将其推送到执行堆栈顶部。 如果在当前函数调用另一个函数,则会发生同样事情。...浏览器将始终执行位于堆栈顶部的当前执行上下文,并且一旦函数执行完当前执行上下文后,它将从栈顶部弹出,把控制权返回到当前栈下一个上下文。 下面的示例显示了递归函数和程序执行堆栈: ? ?...此扫描结果将成为executionContextObjvariableObject。 以下是解释器如何预处理代码伪代码概述: 找一些代码来调用一个函数。 在执行功能代码之前,创建执行上下文

1.1K40

JS执行上下文栈和作用域链

一、JS执行上下文 执行上下文就是当前 JavaScript 代码被解析和执行时所在环境抽象概念, JavaScript 运行任何代码都是在执行上下文中运行。...执行上下文类型分为:全局执行上下文和函数执行上下文执行上下文创建过程,需要做以下几件事: (1)创建变量对象:首先初始化函数参数arguments,提升函数声明和变量声明。...( with 和 eval 能够修改词法作用域,但是不推荐使用,对此不做特别说明)   在 js 是词法作用域,意思就是你变量函数作用域是由你编码位置决定,当然可以通过 apply、call...三、JS执行上下文栈(后面简称执行栈)   执行栈,也叫做调用栈,具有 LIFO (后进先出) 结构,用于存储在代码执行期间创建所有执行上下文。...当栈顶函数运行完成后,其对应函数执行上下文将会从执行Pop出,上下文控制权将移动到当前执行下一个执行上下文

63710

【译】JS执行上下文和环境栈是什么?

这篇文章,我将深入探讨JavaScript一个最基本部分,即执行上下文(或称环境)。...如果在全局代码调用一个函数,程序顺序流就进入被调用函数,创建一个新执行上下文并将该上下文推送到执行顶部。 如果你在当前函数调用另外一个函数,则会发生同样事情。...但是,在JavaScript解释器执行上下文调用都有两个阶段: 创建阶段【调用函数时,但是在执行里面的代码之前】: 创建作用域链 创建变量,函数和参数 确定this值 激活/代码执行阶段: 分配值...此扫描结果将称为executionContextObjvariableObject。 以下是解释器如何评估代码伪概述: 找些代码来调用一个函数 在执行函数代码之前,创建执行上下文。...如果变量名称已存在于变量对象(或活动对象),则不执行任何操作并继续扫描(即跳过)。 确定上下文this。 激活/代码执行阶段: 在上下文中运行/解释功能代码,并在代码逐行执行时分配变量值。

75120

JS到底是怎么执行:一文彻底搞清执行上下文

然后,浏览器JS引擎创建一个特殊环境来处理这段JS代码转换和执行。这个环境称为执行上下文执行上下文包含当前正在运行代码,以及帮助其执行所有内容。...JavaScript引擎在定义函数执行上下文中遍历作用域,以解析其中调用变量和函数,这种做法称为作用域链。 只有当JS引擎无法解析范围链变量时,它才会停止执行并抛出错误。...当脚本在浏览器中加载时,全局上下文被创建为默认上下文JS引擎在其中开始执行代码,并被放置在执行堆栈底部。 然后JS引擎在代码搜索函数调用。...对于每个函数调用,都会为该函数创建一个新FEC,并置于当前正在执行执行上下文之上。 位于执行堆栈顶部执行上下文成为活动执行上下文,并且总是首先由JS引擎执行。...一旦活动执行上下文所有代码执行完毕,JS引擎就会弹出执行堆栈特定函数执行上下文,移动到它下面的下一个函数,以此类推。

1.2K60
领券