关于js的闭包和匿名函数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于js的闭包和匿名函数相关的知识,希望对你有一定的参考价值。

关于js闭包。之前我一直以为是匿名函数,以为封闭式的创建即执行销毁就是闭包,其实这是匿名函数,不一样的。也没有闭包的使用经验。

后来去网上查了下才知道,闭包的意思是:函数内部还有函数,返回一个函数,内部函数可访问外部函数的变量

一个最简单的案例:

a是外部函数,b是内部函数,b可以使用a的变量i,调用a函数返回b函数,执行c既是执行b。其实也就意味着在a函数的外部,读取到了a函数内部的变量值。

a中的变量i将一直在内存中,直至c变量删除。

删除变量:delete c;

{
	let a=function(){
		let i=1;
		let b=function(){
			console.log(i+1)
		}
		return b;
	}
	let c=a();
	c();//2
}

obj.geta()输出2,this代表当前对象。而闭包(内部函数)中的this代表window,这里为什么不输出1呢?因为这个a是let声明赋值的,不会传给window。

return function是直接返回一个匿名函数

{
	let a=1;
	let obj={
		a:2,
		geta:function(){
			console.log(this.a)
			return function(){
				console.log(this.a)
			}
		}
	}
	let c=obj.geta();//2
	c();//undefined
}

用这种方式就可以了,外部将this赋值给一个新变量,再给闭包

{
	let a=1;
	let obj={
		a:2,
		geta:function(){
			let _this=this;//将this赋值给_this再给闭包
			console.log(this.a)
			return function(){
				console.log(_this.a)
			}
		}
	}
	let c=obj.geta();//2
	c();//2
}

 

以上是关于关于js的闭包和匿名函数的主要内容,如果未能解决你的问题,请参考以下文章

js中的匿名函数和闭包总结篇

js中的匿名函数和闭包总结篇

24 jQuery——对象的封装闭包匿名自调用函数

Node.js匿名函数-闭包-Promise

Js基础知识6-JavaScript匿名函数和闭包

自调用匿名函数(匿名闭包)解析与调用