20200229-js闭包_隔离继续

闭包的作用:

让函数内部的局部变量,在函数执行完成后,让外部能够操作这个变量(延长了函数内部的局部变量的生命周期)

在js中,内部作用域可以访问外部作用域
为了某些操作,需要在外部操作内部作用域的变量------通过闭包来进行

       function fn1(){
			var i = 0
			return function(){
				i++
				console.log(i)
			}
		}
		var ret = fn1()
		ret()//i++
		ret()//i++

为什么在fn1 函数执行完成后,依然可以操作局部变量i呢?
这时候闭包就产生了巨大作用
使用Chrome浏览器:

在这里插入图片描述
在fn1即将执行的时候,fn1会进行初始化
变量提前声明,函数提前执行定义
所以fn2已经提前执行定义了,编译器发现fn2使用到了外部fn1函数的变量a,为了能够让fn2正常使用,所以就会构造一个闭包对象。放在fn2函数中,将要使用外部变量保存一份(地址)
在这里插入图片描述
然后通过外部函数,将内部函数返回给全局作用域(一个例子),然后执行这个内部函数(存在一个闭包对象),进行执行内部函数,内部函数发现a变量不在当前的作用域中,于是去找闭包对象,闭包对象提前保存了这个对象。所以可以直接的使用和操作(内部函数怎么操作就怎么操作)。全局中没法直接对这个变量进行操作。

作用:
      1.将一个函数作为另外一个函数的返回值
      2.将函数传递过去给别人使用

针对作用1解释
在这里插入图片描述

针对作用2解释
在这里插入图片描述
也就是说内部函数通过一个闭包对象,保存了需要使用的变量或者函数。在使用的时候从闭包对象中拿出来即可。

匿名函数无法查看到闭包对象

在作用2中:将setTimeOut函数中传递的方法,拿出来才能够看到闭包对象,如果直接传递一个匿名函数的时候,无法在Chrome中查看到这个闭包对象的,但是依然可以使用闭包对象。

闭包的个人理解:

闭包就是内部函数构建了一个闭包对象
这个闭包对象保存了 需要使用的变量(外部函数)
内部函数返回给了,这样内部函数就可以通过闭包对象直接访问需要的变量了
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值