JavaScript中的闭包
作者:bea
1、什么是闭包 闭包,官方对闭包的解释是:一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。 简单的说,Javascript允许使用内部函数---即函数定义和函数表达式位于另一个函数的函数体内。而且,这些内部函数可以访问它们所在的外部函数中声明的所有局部变量、参数和声明的其他内部函数。当其中一个这样的内部函数在包含它们的外部函数之外被调用时,就会形成闭包。 闭包的特点 1 函数嵌套函数 2 函数内部可以引用外部的参数和变量
1、什么是闭包
闭包,官方对闭包的解释是:一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。
简单的说,Javascript允许使用内部函数---即函数定义和函数表达式位于另一个函数的函数体内。而且,这些内部函数可以访问它们所在的外部函数中声明的所有局部变量、参数和声明的其他内部函数。当其中一个这样的内部函数在包含它们的外部函数之外被调用时,就会形成闭包。
闭包的特点
1 函数嵌套函数
2 函数内部可以引用外部的参数和变量
3 参数和变量不会被垃圾回收机制回收
一般函数执行完毕后,局部活动对象就被销毁,内存中仅仅保存全局作用域。但闭包的情况不同!
function fn(){
var a = ;
function fn(){
//可以访问fn中定义的a值
alert( a++ );
}
fn();
}
fn(); //
fn(); //
function fn(){
var a = ;
function fn(){
//可以访问fn中定义的a值
alert( a++ );
}
return fn;//
}
var f = fn();
f(); // 执行完后a还在内存中
f(); //
f = null; //a被回收
以上所述是小编给大家介绍JavaScript中的闭包,希望对大家有所帮助!
猜你喜欢
您可能感兴趣的文章:
- JavaScript实现多种排序算法
- JavaScript中的时间处理小结
- JS设置cookie、读取cookie
- jquery form表单获取内容以及绑定数据
- javascript cookie的简单应用
- javascript的正则匹配方法学习
- 适用于javascript开发者的Processing.js入门教程
- JavaScript设计模式经典之命令模式
- JavaScript设计模式经典之工厂模式
- JavaScript的设计模式经典之建造者模式
- JavaScript的设计模式经典之代理模式
- jQuery实现验证年龄简单思路
- JavaScript实现99乘法表及隔行变色实例代码
- JavaScript中Object.prototype.toString方法的原理
- JavaScript判断变量是否为数组的方法(Array)
- 浅析jQuery Ajax请求参数和返回数据的处理
- jQuery+formdata实现上传进度特效遇到的问题
- JQuery EasyUI的使用
- 使用jQuery监听DOM元素大小变化