通过示例彻底搞懂js闭包

 时间:2024-10-21 18:14:50

1、在sayHello()函数中定义并调用了sayAlert()函数;sayAlert()作为内层函数,可以访问外层函数sayHello()中的text变量。

通过示例彻底搞懂js闭包

2、得到的结果:连续输出3个"item3 undefined"

通过示例彻底搞懂js闭包

3、通过执行buildList函数,返回了一个result,那么这个result存放的是3个匿名函数。然而这三个匿名函数其实就是三个闭包,因为它可以访问到父函数的局部变量。所以闭包内的保留的i是最终的值为3.所以list[3]肯定是undefined. item变量值为item3.改成如下代码:

通过示例彻底搞懂js闭包

4、得到的结果:

通过示例彻底搞懂js闭包

5、这儿虽然传递了一个数组进去,但是返回的是三个自执行的函数。

通过示例彻底搞懂js闭包

6、每次调用newClosure()都会创建独立的闭包,局部变量num与ref的值并不相同。

通过示例彻底搞懂js闭包

7、al坡纠课柩ice变量在sayAlert函数之后定义,这并未影响代码执行。因为返回函数sayAlice2所指向的闭包会包含s锾攒揉敫ayAlice()函数中的所有局部变量,这自然包括了alice变量,因此可以正常打印”Hello Alice”。

通过示例彻底搞懂js闭包

8、首先gAlertNumber,gIncreaseNumber,gSetNumber是三个全局变量,并且其三个值都是匿名函数,然而这三个匿名函数本身都是闭包。他们操作的num都是保存在内存中的同一个num,所有会得出上面的结果。

  • js中的闭包原理详解
  • js函数闭包的作用
  • Python闭包的使用
  • 什么叫闭包?JavaScript
  • 如何使用JavaScript闭包循环生成数组元素
  • 热门搜索
    芍药的功效与作用 缩泉丸的功效与作用 盐酸左氧氟沙星片的功效与作用 小学生运动会投稿 属蛇的和什么属相相克 运动会感悟 消防安全知识讲座 学院和大学有什么区别 草莓什么时候种植 胸片检查什么