理解执行上下文 执行上下文(Execution Context): 函数执行前进行的准备工作(也称执行上下文环境) 运行JavaScript代码时,当代码执行进入一个环境时,就会为该环境创建一个执行上下文...程序代码中基本都会存在函数,那么调用函数,就会进入函数执行环境,对应就会生成该函数的执行上下文。 先插播一个知识点:JS是"单线程"! "单线程"! "单线程"!...JS中管理多个执行上下文 函数编程中,代码中会声明多个函数,对应的执行上下文也会存在多个。...因为JS执行中最先进入全局环境,所以处于"栈底的永远是全局环境的执行上下文"。...常见于递归调用,没有终止条件造成死循环的场景。
定义 当 JS 引擎开始执行预编译生成的代码时,就会进入到一个执行上下文(Executable Code - 简称 EC)。...但是在逻辑上,我们可以将活动的执行上下文看成一个栈结构。栈底部永远是全局上下文(global context),而顶部就是当前活动的执行上下文。执行到当前代码时,上下文入栈,执行完毕后,上下文出栈。...可执行代码有几种 前面说到当引擎执行到可执行代码的时候,就会将当前上下文压入上下文栈中。那么可执行的代码又分为几种?...在这里,我们先假设定义执行上下文栈是一个数组: EC = []; 第一种可执行代码 -- 全局代码: 全局类型代码是在加载外部的 js 文件或者本地 标签中的代码。...functionContext - recursively, functionContext, globalContext ]; // 递归会不断调用下去,因为没有结束条件,所以这是一个死循环
当执行 JS 代码时,会产生三种执行上下文 全局执行上下文 函数执行上下文 eval 执行上下文 每个执行上下文中都有三个重要的属性 变量对象(VO),包含变量、函数声明和函数的形参,该属性只能在全局上下文中访问...作用域链(JS 采用词法作用域,也就是说变量的作用域是在定义时就决定了) this var a = 10 function foo(i) { var b = 20 } foo() 对于上述代码,执行栈中有两个上下文...:全局上下文和函数 foo 上下文。...但是更准确的解释应该是:在生成执行上下文时,会有两个阶段。...() { foo = 10 ; console.log(foo) } 因为当 JS 解释器在遇到非匿名的立即执行函数时,会创建一个辅助的特定对象,然后将函数名称作为这个对象的属性,因此函数内部才可以访问到
定义 当 JS 引擎开始执行预编译生成的代码时,就会进入到一个执行上下文(Executable Code - 简称 EC)。...但是在逻辑上,我们可以将活动的执行上下文看成一个栈结构。栈底部永远是全局上下文(global context),而顶部就是当前活动的执行上下文。执行到当前代码时,上下文入栈,执行完毕后,上下文出栈。...可执行代码有几种 前面说到当引擎执行到可执行代码的时候,就会将当前上下文压入上下文栈中。那么可执行的代码又分为几种?...在这里,我们先假设定义执行上下文栈是一个数组: EC = []; 复制代码 第一种可执行代码 -- 全局代码: 全局类型代码是在加载外部的 js 文件或者本地 标签中的代码。...functionContext - recursively, functionContext, globalContext ]; // 递归会不断调用下去,因为没有结束条件,所以这是一个死循环
每当 JavaScript 代码运行时,它都在执行上下文中运行;调用栈则可以在脚本调用多个函数时,跟踪每个函数在完成执行时应该返回的控制点。 什么是执行上下文?...执行上下文的类型 JavaScript 中有三种执行上下文类型。 全局执行上下文 — 这是默认或者说基础的上下文,任何不在函数内部的代码都在全局上下文中。...函数执行上下文 — 每当一个函数被调用时, 都会为该函数创建一个新的上下文。每个函数都有它自己的执行上下文,不过是在函数被调用时创建的。函数上下文可以有任意多个。...调用栈列表: - greeting 10.当 greeting() 函数中的所有内容都执行完之后,返回到它的调用行继续执行其余的JS代码。 11.把 greeting() 方法从调用栈列表中删除。...到现在,我们已经看过 JavaScript 怎样管理执行上下文了,现在让我们了解 JavaScript 引擎是怎样创建执行上下文的。 创建执行上下文有两个阶段:1) 创建阶段 和 2) 执行阶段。
如果要成为一名优秀的JS开发者,那么对JavaScript程序的内部执行原理要有所了解。本文以最新的ECMA规范中的第八章节为基础,理清JavaScript的词法环境和执行上下文的相关内容。...在执行上下文中记录了代码执行过程中的状态信息,根据不同运行场景,执行上下文会细分为如下几种类型:全局执行上下文:当运行代码是处于全局作用域内,则会生成全局执行上下文,这也是程序最基础的执行上下文。...而执行栈(Execution Context Stack)是用来管理执行期间创建的所有执行上下文的数据结构,它是一个LIFO(后进先出)的栈,它也是我们熟知的JS程序运行过程中的调用栈。...将全局执行上下文压入执行栈,通常JS引擎都有一个指针running指向栈顶元素:图片JS引擎会将全局范围内声明的函数(foo)初始化在全局上下文中,之后开始一行行的执行代码,运行到console就在running...总结本文关于执行上下文的理论知识比较多,不容易马上吸收理解,建议你逐渐消化、反复阅读理解。当你熟悉了执行上下文和词法环境,相信去理解认识更多JS特性和概念时,会更加轻松容易。
类似,EC 就是一段代码涉及到的场景,在代码运行之前,js engine 会做一些变量内存分配,代码上下文关联的准备工作,这就是 EC。...这就是「执行上下文栈」(Execution Context Stack),可以看作是 调用栈的镜像。...由于所有的 js 代码都存在于全局环境中,所以首先会创建 「全局执行上下文」(Global Execution Context),除此之外,js 中每一次的函数调用也会生成 EC,所以栈底肯定会是 全局执行上下文...,首先创建全局执行上下文并设置为 「当前执行上下文」(running execution context): Execution Context = { global object...代码执行到 ln 09 时,因为是对函数的调用,会创建一个新的执行上下文,并置为「当前执行上下文」: foo Execution Context = { this: window,
执行上下文和执行栈是js执行机制中的两个概念,要想深入的对js进行理解与应用,理解js的机制很重要,下面来说一下什么是执行上下文,什么又是执行栈。...从他的类型上来分,我们可以将其分为三类:全局执行上下文、函数执行上下文、Eval 函数执行上下文。 全局执行上下文是是默认的、最基础的执行上下文。...一个程序中只能存在一个全局执行上下文。 函数执行上下文是指在每次调用函数时,都会为该函数创建一个新的执行上下文,这就是函数执行上下文,他可以有无数个。有多少个函数就有多少个函数执行上下文。...引擎会运行执行上下文在执行栈顶端的函数,当此函数运行完成后,其对应的执行上下文将会从执行栈中弹出,上下文控制权将移到当前执行栈的下一个执行上下文。...当 second() 函数执行完成后,它的执行上下文从当前执行栈中弹出,上下文控制权将移到当前执行栈的下一个执行上下文,即 first() 函数的执行上下文。
js执行上下文的类型 1、全局上下文:是基础,默认上下文类型,任何不在函数内的代码都在全局上下文中。...它会执行两件事:创建一个全局window对象,设置this的值等于这个对象,一个程序只有一个全局上下文环境。 2、函数上下文:每当调用一个函数,就会为这个函数创建一个新的上下文。...每个函数都有自己的上下文,函数上下文可以任意多个。 3、eval函数执行上下文:执行在eval函数内部的函数也有自己的函数上下文。...执行上下文的类型,希望对大家有所帮助。...更多js学习指路:js教程 收藏 | 0点赞 | 0打赏
一、执行上下文 单线程 同步执行,只有栈顶的上下文处于执行中,其他上下文需要等待 全局上下文只有唯一的一个,它在浏览器关闭时出栈 函数的执行上下文的个数没有限制 每次某个函数被调用,就会有个新的执行上下文为其创建...—— return 2、函数作用域 js没有块级作用域,而有函数作用域。 函数作用域是指:在函数内声明的所有变量在函数体内是始终可见的。...); result(); // 999 f2()就是闭包 闭包的作用 ---- 四、this 全局函数里,this 等于window 函数被作为某个对象的方法调用时,this等于那个对象 匿名函数执行环境具有全局性...,this指向window (可以通过call()或apply()改变函数执行环境)
上下文环境的初始化在代码执行前完成 JS有三种作用域:全局作用域、函数作用域、eval作用域(不常用,不做介绍)。...在JS代码执行前,首先会对这三种作用域进行上下文环境的准备工作,准备内容如下: 全局作用域的上下文准备工作 将全局变量设为undefined 将函数表达式的值设为undefined 为函数声明直接赋值...运行时才能确定,而全局作用域中的this在准备上下文环境的时候就确定了(window)。...因为在代码运行前的准备上下文环境过程中,函数的初始化已经完成,所以运行时无论函数调用语句在哪儿,JS编译器都能调用这个函数。 若采用函数表达式来定义函数,则函数定义一定要在函数调用语句之前!...JS中作用域只有三种:全局作用域、函数作用域、eval作用域。除此之外就没有作用域了!如:for、if、while等都不是独立的作用域! 因此在里面定义的局部变量都属于其所属的外层作用域。
js如何创建执行上下文 1、创建一个执行分为两个阶段:创建阶段和执行阶段。 2、创建阶段会发生三件事:绑定this指向,也被称为 This Binding、创建词法环境组件、创建变量环境组件。...this 指向 LexicalEnvironment = { ... }, // 词法环境 VariableEnvironment = { ... }, // 变量环境 } 以上就是js...创建执行上下文的方法,希望对大家有所帮助。...更多js学习指路:js教程 收藏 | 0点赞 | 0打赏
Js如何存储执行上下文 1、执行上下文存在于数据栈中。该栈保存代码运行是创建的所有上下文。 栈的特点是后进先出,每创建一个新的上下文,就会压入栈的顶部。...当函数执行完成时,上下文从栈中弹出,控制过程到达栈中的下一个上下文。 2、当js引擎第一次触摸脚本时,它将创建一个全局的上下文,并将其压入栈中。...实例 // 创建全局上下文,入上下文执行栈 var name = 'globalName'; function F1() { // 第一阶段进行后 // 这里this指向window // ...// 创建F1上下文,入上下文执行栈 F1(); // F1出栈 // 全局上下文出栈 以上就是Js存储执行上下文的方法,希望对大家有所帮助。...更多js学习指路:js教程 收藏 | 0点赞 | 0打赏
一、JS执行上下文 执行上下文就是当前 JavaScript 代码被解析和执行时所在环境的抽象概念, JavaScript 中运行任何的代码都是在执行上下文中运行。...执行上下文类型分为:全局执行上下文和函数执行上下文。执行上下文创建过程中,需要做以下几件事: (1)创建变量对象:首先初始化函数的参数arguments,提升函数声明和变量声明。...在 ES6 之前,js 中的作用域分为两种:函数作用域和全局作用域,现在作用域分为:全局作用域、函数作用域、块级作用域。 ...三、JS执行上下文栈(后面简称执行栈) 执行栈,也叫做调用栈,具有 LIFO (后进先出) 结构,用于存储在代码执行期间创建的所有执行上下文。...当栈顶的函数运行完成后,其对应的函数执行上下文将会从执行栈中Pop出,上下文的控制权将移动到当前执行栈的下一个执行上下文。
(设置循环任务)setInterval 设置时间方法循环调用方法 每多少时间执行一次函数 语法: 写法一:setInterval(函数名,时间单位为毫秒) 写法二:setInterval('函数名()'...(设置延迟任务)setTimeout 设置时间方法延迟执行方法 延迟多少时间执行一次函数 语法: 写法一:setTimeout(函数名,时间单位为毫秒) 写法二:setTimeout('函数名()',时间单位为毫秒...(清除循环任务)clearInterval 首先要将之前设置选好任务赋予一个对象 var a=setInterval(函数名,时间单位为毫秒) 在能取到a对象的情况下才可清除 clearInterval
,他就被压入栈中,这很好理解,main函数执行完成必须依赖他的执行。...事件循环 所以,事件循环其实就是js代码借助与浏览器API向消息队列中丢入一些回调函数,等待执行栈放空自己的时候,把消息队列中的回调函数压入到执行栈中执行的这么一个机制。...紧接着runWhileLoopForNSeconds(3);被压入了执行栈中,是一个函数,由于js是单线程的,因此mian也好,runWhileLoopForNSeconds也好,都会在这个执行栈所在在执行上线文中孤独的执行着...('C');被压入了执行栈,然后秒执行了,此时main总算走空了,因此事件循环现在就看消息队列中有没有消息了,已看发现有,嘿,一个一个的丢出来,放到执行栈中来执行。...总结 所以,只有当执行栈中是空的时候,事件循环机制才有机会把消息队列中的任务丢出来执行,换句话说,只有执行栈中有内容在执行,事件循环就不可能给你从消息队列中取任务出来执行。
执行上下文的类型 JS中有三种执行上下文类型: 全局执行上下文:默认的最基础的执行上下文,一个程序只会存在一个全局上下文,它在整个JS脚本的生命周期中都会存在于执行堆栈的最底部,不会被栈弹出销毁。...执行上下文的生命周期 创建阶段 执行阶段 销毁阶段 1.创建阶段 函数执行上下文的创建阶段,发生在函数调用时且在执行函数体内的具体代码之前,在创建阶段,JS引擎会做如下操作: 用当前函数的参数列表(...构建作用域链 确定 this 的值 2.执行阶段 执行阶段中,JS代码开始逐条执行,在这个阶段,JS引擎开始对定义的变量赋值、开始顺着作用域链访问变量、如果内部有函数调用就会创建一个新的执行上下文压入执行栈并把控制权交出...执行上下文栈 当一个脚本运行起来的时候,可能会调用很多函数并产生很多函数执行上下文,为了管理这些执行上下文,JS引擎就创建了“执行上下文栈”(Excution context stack简称ECS)来管理执行上下文...执行上下文栈遵循LIFO(后进先出)的特征,代码执行期间创建的所有执行上下文,都会交给执行上下文栈进行管理。 当JS引擎开始解析脚本代码时,会首先创建一个全局执行上下文,压入栈底。
javascript代码在执行时,会进入一个执行上下文中,执行上下文可以理解为当前代码的运行环境。...当javascript解释器初始执行代码,它首先默认进入全局上下文。每次调用一个函数将会创建一个新的执行上下文。每次新创建的一个执行上下文会被添加到作用域链的顶部,有时也称为执行或调用栈。...浏览器总是运行位于作用域链顶部的当前执行上下文。一旦完成,当前执行上下文将从栈顶被移除并且将控制权归还给之前的执行上下文。 不同执行上下文之间的变量命名冲突通过攀爬作用域链解决,从局部直到全局。...第五步,swapColor的执行上下文弹出之后,继续执行changeColor的可执行代码,遇到其他执行上下文,顺利执行完毕后弹出,这样ECStack就剩下全局执行上下文了,如图所示 ?...最后,,全局执行上下文在浏览器关闭后出栈。需要注意的是,函数执行上下文遇到 return 能直接终止可执行代码的执行,因此会直接将当前上下文弹出栈。
js执行上下文是什么意思 说明 1、执行上下文是指函数调用时在执行栈中产生的当前函数(或全球对象window)的执行环境,该环境如隔绝外部世界的容器边界,保管可访问的变量、this对象等。...2、每次函数调用,实行堆栈顶部都会产生新的执行环境。栈底永远是全局的上下文,栈顶是现在活动状态下执行代码的上下文。... function(y) { let c = 5; console.log(y + c); //4、fn出栈,bar出栈 }; bar(10); // 2、进入bar函数上下文环境 以上就是js...执行上下文的介绍,希望对大家有所帮助。...更多js学习指路:js教程 推荐操作环境:windows7系统、jquery3.2.1版本,DELL G3电脑。
第一部分:执行上下文 1.javascript在执行一个代码段之前,都会进行这些“准备工作”来生成执行上下文 做了哪些准备工作 ? image.png ?...image.png 解析:函数执行时, a)先填充函数的参数,得到 x且得到值10,y:undefined;z:undefined, b)函数声明,function x(){},且覆盖了原来的x:10,...第二部分:执行上下文栈 执行全局代码时,会产生一个执行上下文环境,每次调用函数都又会产生执行上下文环境。 当函数调用完成时,这个上下文环境以及其中的数据都会被消除,再重新回到全局上下文 环境。...处于活动状态的执行上下文环境只有一个。 其实这是一个压栈出栈的过程——执行上下文栈。如下图: ? 看代码演示 ? ?...console.log(a);//函数,函数和变量声明提前,此结果说明函数声明比变量更先; var a =3; function a(){ console.log(a)//不执行
领取专属 10元无门槛券
手把手带您无忧上云