当前位置: 首页 > 编程笔记 >

谈谈我对JavaScript原型和闭包系列理解(随手笔记8)

孟华晖
2023-03-14
本文向大家介绍谈谈我对JavaScript原型和闭包系列理解(随手笔记8),包括了谈谈我对JavaScript原型和闭包系列理解(随手笔记8)的使用技巧和注意事项,需要的朋友参考一下

在上篇文章给大家介绍了《谈谈我对JavaScript原型和闭包系列理解(随手笔记6)》, 谈谈我对JavaScript原型和闭包系列理解(随手笔记9)     可以点击了解详情。

执行上下文栈

执行全局代码时,会产生一个执行上下文环境,每次调用函数都又会产生执行上下文环境。当函数调用完成时,这个上下文环境以及其中的数据都会被消除,再重新回到全局上下文环境。处于活动状态的执行上下文环境只有一个。

压栈出栈过程----执行上下文栈:

var a = 10,    //1. 进入全局上下文环境
  fn,
  bar = function(x) {
   var b = 5;
   fn(x + b); //3. 进入fn函数上下文
  };
fn = function(y) {
 var c = 5;
 console.log(y + c);
};
bar(10);    //2. 进入bar函数上下文环境 

1、在执行之前,首先创建全局上下文环境

 

2、代码执行,执行到bar(10)之前,全局上下文中的变量在执行过程中被赋值。

 

3、执行到bar(10)调用bar函数,同时创建该函数内部的执行上下文环境

 

4、这时候该执行上下文环境进行压栈,设置为活动状态

 

5、bar函数执行到fn(x + b),调用fn函数,创建了fn函数的执行上下文,并压栈,设置为活动状态

 

6、fn函数执行完毕,fn环境出栈,被销毁,释放内存,bar函数变为活动态

 

7、fn函数执行完毕并销毁,意味着bar也执行完毕了,此时bar函数环境出栈,并销毁。全局环境变为活动态。

 

到这里这一段代码的执行过程就完毕了。

根据原作者的描述:

其中上下文环境的变量赋值过程我省略了许多,因为那些并不难,一看就知道。

的确!代码的大概执行过程跑完后,就能很清楚的知道各个执行环境中的变量是个怎样的状态。

讲到这里,我不得不很遗憾的跟大家说:其实以上我们所演示的是一种比较理想的情况。有一种情况,而且是很常用的一种情况,无法做到这样干净利落的说销毁就销毁。这种情况就是伟大的——闭包。要说闭包,咱们还得先从自由变量和作用域说起。

以上内容是小编给大家分享我对JavaScript原型和闭包系列理解(随手笔记8),希望大家喜欢。

 类似资料:
  • 本文向大家介绍谈谈我对JavaScript原型和闭包系列理解(随手笔记6),包括了谈谈我对JavaScript原型和闭包系列理解(随手笔记6)的使用技巧和注意事项,需要的朋友参考一下 相关阅读:谈谈我对JavaScript原型和闭包系列理解(随手笔记8)   谈谈我对JavaScript原型和闭包系列理解(随手笔记9) 什么是闭包 闭包是什么?闭包是Closure,这是静态语言所不具有的一个新特性

  • 本文向大家介绍谈谈我对JavaScript原型和闭包系列理解(随手笔记9),包括了谈谈我对JavaScript原型和闭包系列理解(随手笔记9)的使用技巧和注意事项,需要的朋友参考一下 相关阅读:谈谈我对JavaScript原型和闭包系列理解(随手笔记6)   谈谈我对JavaScript原型和闭包系列理解(随手笔记8) 作用域 引用《JavaScript语言精粹和编程实践》上对作用域的定义: 变量

  • 本文向大家介绍谈谈你对闭包的理解?相关面试题,主要包含被问及谈谈你对闭包的理解?时的应答技巧和注意事项,需要的朋友参考一下 说明: bar在foo函数的代码块中定义。我们称bar是foo的内部函数。 在bar的局部作用域中可以直接访问foo局部作用域中定义的m、n变量。 简单的说,这种内部函数可以使用外部函数变量的行为,就叫闭包。 闭包的意义与应用  

  • 本文向大家介绍小白谈谈对JS原型链的理解,包括了小白谈谈对JS原型链的理解的使用技巧和注意事项,需要的朋友参考一下 原型链理解起来有点绕了,网上资料也是很多,每次晚上睡不着的时候总喜欢在网上找点原型链和闭包的文章看,效果极好。 不要纠结于那一堆术语了,那除了让你脑筋拧成麻花,真的不能帮你什么。简单粗暴点看原型链吧,想点与代码无关的事,比如人、妖以及人妖。 1)人是人他妈生的,妖是妖他妈生的。人和妖

  • 本文向大家介绍谈谈对JavaScript原生拖放的深入理解,包括了谈谈对JavaScript原生拖放的深入理解的使用技巧和注意事项,需要的朋友参考一下 前面的话   拖放(drag-and-drop,DnD)其实是两个动作——拖和放。所以,它涉及到两个元素。一个是被拖的元素,称为拖放源;另一个是要放的目标,称为拖放目标。本文将通过拆分这两个概念来详细介绍原生拖放 拖放源   什么样的元素才是拖放源

  • 本文向大家介绍JavaScript闭包原理与用法学习笔记,包括了JavaScript闭包原理与用法学习笔记的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JavaScript闭包原理与用法。分享给大家供大家参考,具体如下: 闭包(Closure) 闭包是一个函数和词法环境的组合,函数声明在这个词法环境中。 词法作用域: 看下面的一个例子: init()创建了一个局部变量name和一个函数d