闭包理解
来源:互联网 发布:矿用道夹板数据 编辑:程序博客网 时间:2024/06/06 02:33
## 先上例子 ##
function f1(){ var n=999; function f2(){ alert(n); } return f2;}var result=f1();result(); // 999
## 概念 ##
简单的说,闭包就是能够读取其他函数内部变量的函数。由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成”定义在一个函数内部的函数”。
所以,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。
## 用途 ##
一个是前面提到的可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中。
function f1(){ var n=999; nAdd=function(){n+=1} function f2(){ alert(n); } return f2; } var result=f1(); result(); // 999 nAdd(); result(); // 1000
result()运行两次,局部变量n值始终保存在内存中。
为什么会这样呢?原因就在于f1是f2的父函数,而f2被赋给了一个全局变量result,这导致f2始终在内存中,而f2的存在依赖于f1,因此f1也始终在内存中,不会在调用结束后,被垃圾回收机制(garbage collection)回收。
另一个值得注意的地方,就是”nAdd=function(){n+=1}”这一行,首先在nAdd前面没有使用var关键字,因此nAdd是一个全局变量,而不是局部变量。其次,nAdd的值是一个匿名函数(anonymous function),而这个匿名函数本身也是一个闭包,所以nAdd相当于是一个setter,可以在函数外部对函数内部的局部变量进行操作。
注意
1)由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。
2)闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。
- 理解 JavaScript 闭包
- 理解 JavaScript 闭包
- 理解 JavaScript 闭包
- 理解 JavaScript 闭包
- 理解 JavaScript 闭包
- 理解 JavaScript 闭包
- 理解 JavaScript 闭包
- 理解 JavaScript 闭包
- javascript 闭包理解
- 深刻理解闭包
- 理解 JavaScript 闭包
- 理解 JavaScript 闭包
- 深入理解闭包
- 快速理解闭包
- 深入理解闭包
- 理解js闭包
- 理解 JavaScript 闭包
- 理解JavaScript 闭包
- 欢迎使用CSDN-markdown编辑器
- 《Data Mining》学习——可以挖掘什么类型的数据?
- 1099. Build A Binary Search Tree (30)
- 使用mybatis自带工具,自动生成表对应domain、mapper.xml以及dao
- 安装PyGraphics包 (python import media模块)(ampy文件在我这里下载就行,原文链接失效)
- 闭包理解
- HDU
- Linux基础之kickstart 自动安装
- java多线程(1)Thread和Runnable
- springmvc @RestController restful风格的用法
- BeAlert 一款alert和confirm美化插件(优化)
- session的钝化和活化
- 3.Springboot 之 文件结构和配置文件
- Mybatis 3.1中 Mapper XML 文件 的学习详解