闭包函数是什么?在开始学习的闭包的时候,你们很能都比较难理解.就从他的官方解释来讲,都是比较概念化的.c++
不过咱们也仍是从闭包的含义出发. web
闭包是指函数有自由独立的变量。换句话说,定义在闭包中的函数能够“记忆”它建立时候的环境。 编程
官方解释说完后,咱们先来看一个简单计数的例子. 微信
var c = 0; function count(){ c++; } count();// 1 count();// 2
这个例子是利用了全局变量来实现,可是这里有个问题是,c这个变量也容易被其余方式所调用,这时候就可能会改变 c 的存储值.形成这个count计数的失效.那怎么很好的处理这个问题呢!咱们会想到的是使用局部变量的方式来处理.好比: 闭包
function count(){ var c = 0; function add(){ c++; } add(); } count();// c = 1 count();// c = 1
由于这样建立以后,内部变量只存在于count函数建立执行的时候,执行完以后,整个函数就会被丢弃掉.就没法达到有记忆的能力.那要怎么来实现呢?那咱们就用闭包来解决.我要从新提一次:闭包 = 函数 + 环境 函数
function count(){ var c = 0; function add(){ c++; } return add; } var ct = count(); ct(); // c = 1 ct(); // c = 2
这个时候咱们就能够经过这个闭包来完成计数的能力.ct就是一个闭包函数,内部的环境就是这个局部变量 c. 这里咱们达到的就是内部数据,外部来操做.那闭包除了这个还有什么其余功能呢?学习
这有点像JAVA的私有方法或者私有变量,只能容许本身来操做!若是外部操做,就须要设定公开的方法来操做. spa
var person = (function(){ var _name = "编程的人"; var age = 20; return { add:function(){ age++; }, jian:function(){ age--; }, getAge:function() { return age; }, getName:function(){ return _name; }, setName: function (name) { _name = name; } } })(); person.add(); var age = person.getAge(); console.log(age) person.setName("编程的人公众号:bianchengderen") console.log(person.getName())
这里应该很容易理解了吧! 有点面向对象编程的感受.固然Javascript如今也有面向对象编程的特色.这点咱们之后来讲明.
orm
目前为止,咱们从计数到内部私有化的例子,来讲明闭包,但愿你们能简单明白其中的道理,固然闭包还有其余的功能利用,是比较方便的. 对象
本文属于吴统威的博客,微信公众号:bianchengderen 的原创文章,转载时请注明出处及相应连接:http://www.wutongwei.com/front/infor_showone.tweb?id=157 ,欢迎你们传播与分享.