js 闭包 具体作用?
5个回答
2021-11-16 · 学动漫、设计、电竞、电商、短视频、软件等
关注
展开全部
闭包是指有权访问另外一个函数作用域中的变量的函数。
闭包就是函数的局部变量集合,只是这些局部变量在函数返回后会继续存在。闭包就是就是函数的“堆栈”在函数返回后并不释放,我们也可以理解为这些函数堆栈并不在栈上分配而是在堆上分配。当在一个函数内定义另外一个函数就会产生闭包。
作用是:匿名自执行函数:我们知道所有的变量,如果不加上var关键字,则默认的会添加到全局对象的属性上去,这样的临时变量加入全局对象有很多坏处,比如:别的函数可能误用这些变量;造成全局对象过于庞大,影响访问速度(因为变量的取值是需要从原型链上遍历的)。除了每次使用变量都是用var关键字外,我们在实际情况下经常遇到这样一种情况,即有的函数只需要执行一次,其内部变量无需维护,可以用闭包。
结果缓存:我们开发中会碰到很多情况,设想我们有一个处理过程很耗时的函数对象,每次调用都会花费很长时间,那么我们就需要将计算出来的值存储起来,当调用这个函数的时候,首先在缓存中查找,如果找不到,则进行计算,然后更新缓存并返回值,如果找到了,直接返回查找到的值即可。闭包正是可以做到这一点,因为它不会释放外部的引用,从而函数内部的值可以得以保留。
闭包就是函数的局部变量集合,只是这些局部变量在函数返回后会继续存在。闭包就是就是函数的“堆栈”在函数返回后并不释放,我们也可以理解为这些函数堆栈并不在栈上分配而是在堆上分配。当在一个函数内定义另外一个函数就会产生闭包。
作用是:匿名自执行函数:我们知道所有的变量,如果不加上var关键字,则默认的会添加到全局对象的属性上去,这样的临时变量加入全局对象有很多坏处,比如:别的函数可能误用这些变量;造成全局对象过于庞大,影响访问速度(因为变量的取值是需要从原型链上遍历的)。除了每次使用变量都是用var关键字外,我们在实际情况下经常遇到这样一种情况,即有的函数只需要执行一次,其内部变量无需维护,可以用闭包。
结果缓存:我们开发中会碰到很多情况,设想我们有一个处理过程很耗时的函数对象,每次调用都会花费很长时间,那么我们就需要将计算出来的值存储起来,当调用这个函数的时候,首先在缓存中查找,如果找不到,则进行计算,然后更新缓存并返回值,如果找到了,直接返回查找到的值即可。闭包正是可以做到这一点,因为它不会释放外部的引用,从而函数内部的值可以得以保留。
展开全部
闭包开发的时候用的很少 但是 用到的时候 几乎都是不可被别的方式替代的 但凡遇到 永久 ,保护等关键字就用闭包 闭包就是 让一个函数的活动对象
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
js的函数可以当作像object, array之类的类型一样作为变量的值使用, 如果在一个函数里创建另外一个函数并且内部的函数使用到了外面的函数的变量那么就构成一个闭包, 这个外面的函数的变量的值会为闭包的函数一直保存直到闭包函数被内存回收掉为止...
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
1.变量作用域 要理解闭包,首先要理解javascript的特殊的变量作用域。 变量的作用域...
2.如何从外部读取函数内部的局部变量? 出于种种原因,我们有时候需要获取到函数内部的局部变量...
3.闭包的概念 上面代码中的f2函数,就是闭包。 各种专业文献的闭包定义都非常抽象,我的理解...
2.如何从外部读取函数内部的局部变量? 出于种种原因,我们有时候需要获取到函数内部的局部变量...
3.闭包的概念 上面代码中的f2函数,就是闭包。 各种专业文献的闭包定义都非常抽象,我的理解...
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
function Counter(start){
var count = start;
return{
increment:function(){
count++;
},
get:function(){
return count;
}
}
}
var foo = Counter(4);
foo.increment();
foo.get();// 5
var count = start;
return{
increment:function(){
count++;
},
get:function(){
return count;
}
}
}
var foo = Counter(4);
foo.increment();
foo.get();// 5
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询