博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
为什么要使用闭包和如何使用闭包
阅读量:6504 次
发布时间:2019-06-24

本文共 1010 字,大约阅读时间需要 3 分钟。

闭包

JS中的闭包是一个我们经常遇到的名词,到底什么是闭包?为什么我们要使用闭包?又该如何使用闭包呢?

为什么我们需要闭包

首先来看一个例子,我们来实现一个计数器。

var counter = 0;function add() {   return counter += 1;}add();add();add();// 计数器现在为 3

现在我们已经达到了目的,可是问题来了,代码中的任何一个函数都可以随意改变counter的值,所以这个计数器并不完美。那我们把counter放在add函数里面不就好了么?

function add() {    var counter = 0;    return counter += 1;} add();add();add();// 本意是想输出 3, 但输出的都是 1

所以这样做的话,每次调用add函数,counter的值都要被初始化为0,还是达不到我们的目的。

如何使用闭包

所以这时候我们就要用闭包去解决这个问题了,先看代码。

var add = (function () {    var counter = 0;    return function () {return counter += 1;}})();add();add();add();// 计数器为 3

这时候我们完美实现了计数器。这段非常精简,可以拆分成如下等价代码。

function outerFunction () {     var counter = 0;     function innerFunction (){         return counter += 1;     }     return innerFunction;}var add = outerFunction();add();add();add();// 计数器为 3

这时候的add就形成了一个闭包。一个闭包由两部分组成,函数和创建该函数的环境。环境是由环境中的局部变量组成的。对于闭包add来说,它由函数innerFunction和变量counter组成,所以这时候add是可以访问变量counter的。

总结

所以闭包的功能就是使一个函数能访问另一个函数作用域中的变量。形成闭包之后,该变量不会被垃圾回收机制回收。

闭包的原理其实还是作用域。

使用闭包的优点是可以避免全局变量污染,缺点是容易造成内存泄露。

转载地址:http://ydqyo.baihongyu.com/

你可能感兴趣的文章
给django视图类添加装饰器
查看>>
简述 clearfix 的原理
查看>>
【Project Euler】530 GCD of Divisors 莫比乌斯反演
查看>>
luogu P1280 尼克的任务 序列DP
查看>>
iphone UIView的一些基本方法理解
查看>>
sys.check_constraints
查看>>
vue问题
查看>>
ThinkPHP 框架学习
查看>>
css3箭头效果
查看>>
MathType在手,公式不求人!
查看>>
测试用例设计
查看>>
三层架构
查看>>
Python变量类型(l整型,长整形,浮点型,复数,列表,元组,字典)学习
查看>>
解决方案(.sln)文件
查看>>
【Treap】bzoj1588-HNOI2002营业额统计
查看>>
第六周作业
查看>>
利用ZYNQ SOC快速打开算法验证通路(5)——system generator算法IP导入IP integrator
查看>>
指针和引用的区别
查看>>
运行PHP出现No input file specified错误解决办法
查看>>
【重建】从FJOI2016一试谈起
查看>>