第 3-6 行 。我们有一个新的函数声明,我们在createAdder执行上下文中创建一个变量addNumbers 。这很重要,addnumber只存在于createAdder执行上下文中 。我们将函数定义存储在名为 ``addNumbers``` 的自有变量中 。 第7行,我们返回变量addNumbers的内容 。js引擎查找一个名为addNumbers的变量并找到它,这是一个函数定义 。好的,函数可以返回任何东西,包括函数定义 。我们返addNumbers的定义 。第4行和第5行括号之间的内容构成该函数定义 。 返回时,createAdder执行上下文将被销毁 。addNumbers 变量不再存在 。但addNumbers函数定义仍然存在,因为它返回并赋值给了adder 变量 。 第10行 。我们在全局执行上下文中定义了一个新的变量 sum,先赋值为 undefined; 接下来我们需要执行一个函数 。哪个函数? 是名为adder变量中定义的函数 。我们在全局执行上下文中查找它,果然找到了它,这个函数有两个参数 。 让我们查找这两个参数,第一个是我们在步骤1中定义的变量val,它表示数字7,第二个是数字8 。 现在我们要执行这个函数,函数定义概述在第3-5行,因为这个函数是匿名,为了方便理解,我们暂且叫它adder吧 。这时创建一个adder函数执行上下文,在adder执行上下文中创建了两个新变量 a 和 b 。它们分别被赋值为 7 和 8,因为这些是我们在上一步传递给函数的参数 。 第 4 行 。在adder执行上下文中声明了一个名为ret的新变量, 第 4 行 。将变量a的内容和变量b的内容相加得15并赋给ret变量 。 ret变量从该函数返回 。这个匿名函数执行上下文被销毁,从调用堆栈中删除,变量a、b和ret不再存在 。 返回值被分配给我们在步骤9中定义的sum变量 。 我们将sum的值打印到控制台 。 如预期,控制台将打印15 。我们在这里确实经历了很多困难,我想在这里说明几点 。首先,函数定义可以存储在变量中,函数定义在程序调用之前是不可见的 。其次,每次调用函数时,都会(临时)创建一个本地执行上下文 。当函数完成时,执行上下文将消失 。函数在遇到return或右括号}时执行完成 。最后,一个闭包看看下面的代码,并试着弄清楚会发生什么 。

文章插图
现在,我们已经从前两个示例中掌握了它的诀窍,让我们按照预期的方式快速执行它:
- 第 1-8 行 。我们在全局执行上下文中创建了一个新的变量createCounter,并赋值了一个的函数定义 。
- 第9行 。我们在全局执行上下文中声明了一个名为increment的新变量 。
- 第9行 。我们需要调用createCounter函数并将其返回值赋给increment变量 。
- 第 1-8行 。调用函数,创建新的本地执行上下文 。
- 第2行 。在本地执行上下文中,声明一个名为counter的新变量并赋值为 0;
- 第 3-6行 。声明一个名为myFunction的新变量,变量在本地执行上下文中声明,变量的内容是为第4行和第5行所定义 。
- 第7行 。返回myFunction变量的内容,删除本地执行上下文 。变量myFunction和counter不再存在 。此时控制权回到了调用上下文 。
- 第9行 。在调用上下文(全局执行上下文)中,createCounter返回的值赋给了increment,变量increment现在包含一个函数定义内容为createCounter返回的函数 。它不再标记为myFunction````,但它的定义是相同的 。在全局上下文中,它是的标记为labeledincrement``` 。
- 第10行 。声明一个新变量 c1 。
- 继续第10行 。查找increment变量,它是一个函数并调用它 。它包含前面返回的函数定义,如第4-5行所定义的 。
- 创建一个新的执行上下文 。没有参数,开始执行函数 。
- 第4行 。counter=counter + 1 。在本地执行上下文中查找counter变量 。我们只是创建了那个上下文,从来没有声明任何局部变量 。让我们看看全局执行上下文 。这里也没有counter变量 。Javascript会将其计算为counter = undefined + 1,声明一个标记为counter的新局部变量,并将其赋值为number 1,因为undefined被当作值为 0 。
- 第5行 。我们变量counter的值 1,我们销毁本地执行上下文和counter变量 。
- 回到第10行 。返回值1被赋给c1 。
- 第11行 。重复步骤10-14,c2也被赋值为1 。
- 第12行 。重复步骤10-14,c3也被赋值为1 。
- 第13行 。我们打印变量c1 c2和c3的内容 。
你自己试试,看看会发生什么 。你会将注意到,它并不像从我上面的解释中所期望的那样记录1,1,1 。而是记录1,2,3 。这个是为什么?
推荐阅读
-
Troy时尚穿搭|这样搭配起来,高级时髦显气质,秋天必备的衬衫
-
-
好六网|貂蝉加强成法王,伽罗下神坛,赵云终于加强了,正式服海啸级调整
-
侃军讯事|利用这个,能让监管者传送掉洞,第五人格:传送有两个隐藏机制
-
-
足球隽言TB|像拜仁那样提前2轮夺冠!比勒费尔德11年后重返德甲
-
|意媒:国米可能用什克+B罗,与切尔西交换坎特+埃莫森
-
女人过了50岁,尽量别留长发、穿老年装!换成这些打扮更洋气好看
-
|美国航天局30日直播画面显示,美国“毅力”号火星车从佛罗里达州卡纳维拉尔角空军基地升空
-
-
平心说篮球■大家觉得可能吗?,20岁小前锋扬言要超过詹姆斯
-
-
-
王薪凯|专访王薪凯:遇上杜锋指导非常幸运 在联哥身上学到很多精神
-
萧毅哥|结果8年后周杰伦靠他红透半边天,职高毕业打工被人看不起
-
卡哇伊|桃花强势逆袭,告别单身收获甜蜜的三大星座!,未来十天
-
-
共同投资|百亿第三代半导体项目“敲定”,露笑科技能继续“笑”吗?
-
旅行百事通▲因为明朝的崇祯皇帝,成为热门景区,北京城内的“小山丘”
-
太平洋电脑网 327 个市场 1.6 亿用户,AT&T 向全国性 5G 网络迈进,覆盖