闭包

1. 简介

闭包就是能够读取其他函数内部变量的函数。只有函数内部的子函数才能读取局部变
量,在本质上,闭包是函数内部和函数外部连接起来的桥梁。

当函数可以记住并访问所在词法作用域时,就产生了闭包,即使函数是在当前词法作
用域之外执行

2.定义

如果在一个内部函数里,对在外部作用域(但不是全局作用域)的变量进行引用,
那么内部函数就被认为是闭包(closure)。

3.特点

1.可以读取自身函数外部的变量(沿着作用域链寻找)先从自身开始查找,如果自身		 
没有才会继续往上级查找,自身如果拥有将直接调用。(哪个离的最近就用哪一
个)
2.延长内部变量的生命周期
3.函数b嵌套在函数a内部
4.函数a返回函数b

4.作用

在函数a执行完并返回后,闭包使得JavaScript的垃圾回收机制不会收回a所占用的资源,因为a
的内部函数b的执行需要依赖a中的变量,闭包需要循序渐进的过程。

5.构成

闭包由俩个部分构成:
	- 函数 		
	- 以及创建该函数的环境

6.应用场景

1.保护函数内的变量安全。函数a中只有函数b才能访问,而无法通过其他途径访问到,因此保
	护了i的安全性。
2.在内存中维持一个变量
demo:

	var test = (function() {
		var a = 1;
		function add(val){
			a += val;
		}
		return {
			add1() {
				add(1);
			},
			add2() {
				add(2);
			},
			result() {
				return a;
			}
		}
	})();
	这种方式也叫作模块模式

7.缺点

滥用闭包会造成内存泄露,因为闭包中引用到的包裹函数中定义的变量都永远不会被释放,所
以我们应该在必要的时候,及时释放这个闭包函数

8.如何产生闭包

作用域应用的特殊情况,有两种表现:
1.函数作为参数被传递
2.函数作为返回值被返回

// 函数作为返回值
		function create() {
		    const a = 100
		    return function () {
		        console.log(a)
		    }
		}
		
		const fn = create()
		const a = 200
		fn() // 100

// 函数作为参数被传递
		function print(fn) {
		    const a = 200
		    fn()
		}
		const a = 100
		function fn() {
		    console.log(a)
		}
		print(fn) // 100
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值