美文网首页
浅谈JavaScript中的闭包

浅谈JavaScript中的闭包

作者: lovelydong | 来源:发表于2017-08-20 18:28 被阅读0次

闭包是指有权访问另一个函数作用域中的变量的函数,个人认为闭包最大的用处就是防止对全局作用域的污染。 试想如果我们把一些仅仅只用到一两次的变量都声明在全局作用域中,最后肯定是容易出错且不可维护的。而闭包最神奇的地方就是能在一个函数外访问函数中的局部变量,把这些变量用闭包的形式放在函数中便能避免污染。

一、闭包是什么?

JavaScript高级程序设计》中写道:“闭包是指有权访问另一个函数作用域中的变量的函数”,如果用下定义的观点看,这句话就是说“闭包是函数”,我带着怀疑的心态又去网上找了找,发现什么说法都有,终究没能明白闭包的含义,还是看代码来得直接。

function outter()

{

var sky="blue";

function inner()

{console.log(sky); 

 }

return inner;}

var result=outter();

result();//"blue"

这段代码就包含一个简单的闭包:outter函数的返回值是一个函数,即inner。inner在outter内部,理所当然能访问到局部变量sky,但当inner作为outter的返回值赋给outter外的全局变量时,神奇的事情发生了:在全局作用域中访问到了sky,这就是闭包。

二、闭包的原理?

每个函数都有自己的执行环境,当一个函数被执行时,它的执行环境就会被推入环境栈,其活动对象(存储环境中定义的变量及函数)加入作用域链中,一旦函数执行完,栈将其环境弹出,活动对象被销毁。·

对于上面的例子来说,outter执行完之后将返回inner给了result,outter的执行环境从环境栈弹出,控制权交给全局环境,outter的活动对象理应被销毁。但此时inner已经存储在全局活动对象中了,同时inner需要访问sky,所以outter的活动对象没有被销毁,即使result执行完毕,outter的活动对象依然存在于作用域链中,只有当result被销毁

result= null;

outter的活动对象才会彻底释放。

三、闭包有什么用?

说了这么多,闭包到底有什么用呢?我个人认为闭包最大的用处就是防止对全局作用域的污染。 试想如果我们把一些仅仅只用到一两次的变量都声明在全局作用域中,最后肯定是容易出错且不可维护的。而闭包最神奇的地方就是能在一个函数外访问函数中的局部变量,把这些变量用闭包的形式放在函数中便能避免污染。

四、Caveat

闭包将函数的活动对象维持在内存中,过度使用闭包会导致内存占用过多;

闭包只能取得外部函数中任何变量的最后一个值,在使用循环且返回的函数中带有循环变量时会得到错误结果;

当返回的函数为匿名函数时,注意匿名函数中的this指的是window对象。

相关文章

  • 浅谈Javascript中的闭包

    在学习Javascript脚本语言的路上,闭包一直困惑着每一个刚接触这门语言的程序猿。 ——存在的即是合理的。首...

  • 浅谈JavaScript中的闭包

    闭包是指有权访问另一个函数作用域中的变量的函数,个人认为闭包最大的用处就是防止对全局作用域的污染。 试想如果我们把...

  • 浅谈JavaScript中的闭包

    废话 闭包,这个词甚至让很多人看到都觉得头疼,有的人说这东西非常好用,有人说不懂是啥东西... 引用一段JavaS...

  • 浅谈JavaScript中的闭包

    大家好,我是一名前端全栈工程师,我的名字叫袁愈谷,曾经也这条路上的茫茫一员,经过不断努力学习,技术不断的进步,为了...

  • 学习JavaScript闭包和作用域笔记

    JS JavaScript闭包和作用域 闭包 JavaScript高级程序设计中对闭包的定义:闭包是指有权访问另外...

  • 浅谈 JavaScript 闭包

    相信学习 JavaScript 的同学都知道「闭包(Closure)」,这个概念在 JavaScript 中是非常...

  • 浅谈JavaScript闭包

    闭包就是指一个有权访问另外一个函数作用域中的变量的函数。--《JavaScript高级程序第三版》 本人对于闭包初...

  • JavaScript闭包浅谈

    一.闭包 1、什么是闭包 闭:闭合,关闭,封闭。包:包裹,包起来。一个具有封闭的对外不公开的, 包裹结构, 或空间...

  • javascript中闭包是什么

    javascript中闭包是什么 JavaScript 变量可以是局部变量或全局变量。私有变量可以用到闭包。闭包就...

  • JavaScript 闭包问题

    1.闭包的概念 JavaScript中什么是闭包?首先我们要知道在JavaScript中,函数中声明变量函数外是无...

网友评论

      本文标题:浅谈JavaScript中的闭包

      本文链接:https://www.haomeiwen.com/subject/mggfdxtx.html