轻松学习Javascript闭包函数

作者:喜爱编程的人 时间:2024-04-28 09:46:35 

闭包函数是什么?在开始学习的闭包的时候,大家很能都比较难理解.就从他的官方解释来说,都是比较概念化的.

不过我们也还是从闭包的含义出发。
闭包是指函数有自由独立的变量。换句话说,定义在闭包中的函数可以“记忆”它创建时候的环境。
官方解释说完后,我们先来看一个简单计数的例子.

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的私有方法或者私有变量,只能允许自己来操作!如果外部操作,就需要设定公开的方法来操作.


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现在也有面向对象编程的特点.这点我们以后来说明.
目前为止,我们从计数到内部私有化的例子,来说明闭包,希望大家能简单明白其中的道理,当然闭包还有其他的功能利用是比较方便的。

标签:js,闭包函数
0
投稿

猜你喜欢

  • Pytorch实现各种2d卷积示例

    2023-06-20 16:17:29
  • Javascript 中 var 和 let 、const 的区别及使用方法

    2024-05-09 15:07:41
  • 对Python 多线程统计所有csv文件的行数方法详解

    2021-09-09 04:56:44
  • Node.js和PHP根据ip获取地理位置的方法

    2023-11-14 21:23:13
  • xmlHttp msxml3.dll 错误 '800c0008' 解决办法

    2008-08-31 20:44:00
  • Python基于Google Bard实现交互式聊天机器人

    2022-12-14 22:05:20
  • Thinkphp结合ajaxFileUpload实现ajax异步图片传输全套代码

    2023-06-14 04:01:53
  • 浅析Python+OpenCV使用摄像头追踪人脸面部血液变化实现脉搏评估

    2023-08-05 18:46:48
  • 如何将数据库里的记录生成一个Excel文件?

    2009-12-03 20:09:00
  • 给网页添加打印功能按钮

    2008-12-12 13:11:00
  • python3实现域名查询和whois查询功能

    2023-09-19 19:35:12
  • asp如何建立MYSQL数据库的连接?

    2009-11-26 20:30:00
  • sqlserver巧用row_number和partition by分组取top数据

    2024-01-28 12:33:39
  • Python中栈的详细介绍

    2023-05-16 07:22:02
  • js中各浏览器中鼠标按键值的差异

    2024-05-05 09:15:28
  • 用 Python 元类的特性实现 ORM 框架

    2022-02-12 12:45:24
  • Python变量及数据类型用法原理汇总

    2022-12-04 11:11:41
  • python matplotlib 绘图 和 dpi对应关系详解

    2023-12-11 18:13:43
  • Python实现将蓝底照片转化为白底照片功能完整实例

    2021-06-08 21:40:55
  • python压缩和解压缩模块之zlib的用法

    2023-09-19 08:32:07
  • asp之家 网络编程 m.aspxhome.com