闭包

闭包是一种保护私有变量的机制,在函数执行时形成私有的作用域,保护里面的私有变量不受外界干扰。直观的说就是形成一个不销毁的栈环境。(这个是菜鸟教程里的)
想要理解闭包,我们先来一个没有闭包引发的问题:

<body>
	<input type="button" value="1"/>
	<input type="button" value="2"/>
	<input type="button" value="3"/>
</body>
<script>
	//获取所以input
	var btns = document.getElementsByTagName('input');
	//遍历input
	for(var i = 0;i < btns.length;i++){
		//一个一个绑定点击事件
		btns[i].addEventListener('click',function(){
			//打印i
			console.log(i);
		});
	}
</script>

运行结果:
在这里插入图片描述
发现不管点击那个input打印的 i 都是3,因为遍历结束后 i 的值就为3,所以打印的就是3,但是我们想要打印的 i 是input的索引,也就是第几个input?
此时就可以使用闭包了,闭包里的变量是私有的,不会受到外界的干扰,如下:

<body>
	<input type="button" value="1"/>
	<input type="button" value="2"/>
	<input type="button" value="3"/>
</body>
<script>
	var btns = document.getElementsByTagName('input');
	//上面的代码是一样的
	//遍历
	for(var i = 0;i < btns.length;i++){
		//这里就使用闭包了,格式(function(){})()
		//闭包里的function(){}会自动执行,每次循环都会执行
		(function(i){//i是形参
			//可以理解为:每次循环都形成一个变量i,该变量只属于该闭包专属的值
			//使用i来绑定点击事件
			btns[i].addEventListener('click',function(){
				//此时打印的i是属于该闭包的专属值
				console.log(i);
			});
		})(i)
	}
</script>

运行结果:
在这里插入图片描述
总结:使用闭包来形成私有的作用域,让变量的值不会随便被改变

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值