闭包——读《阮一峰的日志》

【闭包】:就是能够读取其他函数内部变量的函数(声明这个函数为变量result,然后调用它就可读取内部参数的值了)。Javascript语言的特殊之处,就在于函数内部局部变量可以直接读取全局变量,但是反过来:外部全局变量不能读取内部的局部变量。往往有时我们需要读取内容变量时,可利用Javascript语言特有的"链式作用域"结构——子对象可以一级一级地向上寻找所有父对象的变量(内部局部变量特性),在函数f1()内容创建一个函数f2(),利用f2()读取f1()内部的变量进行输出return f2,最后在最外层调用一个新变量就可读取f1()内部需要的参数了。

  function f1(){

    var n=999;

    function f2(){
      alert(n);
    }

    return f2;

  }

  var result=f1();

  result(); // 999

一、作用:

  // 闭包的最大用处有两个,一个是的可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中。

  function f1(){

    var n=999;

    nAdd = function(){n+=1};

    function f2(){
      alert(n);
    }

    return f2;

  }

  var result=f1();

  result(); // 999

  nAdd();

  result(); // 1000

二、反思:

1)由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除;

2)闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。

三、延伸:

  //this指代全局变量问题,如何读取局部变量?
  var name = "The Window";

  var object = {
    name : "My Object",

    getNameFunc : function(){
      var that = this; // 防止this指代的是最外层的全局变量
      return function(){
        return that.name;
      };

    }

  };

  alert(object.getNameFunc()()); // My Object;不声明var that = this结果为The Window

详情请参考:http://www.ruanyifeng.com/blog/2009/08/learning_javascript_closures.html

原文地址:https://www.cnblogs.com/wheatCatcher/p/8508918.html

时间: 2024-08-30 03:34:38

闭包——读《阮一峰的日志》的相关文章

读阮一峰对《javascript语言精粹》的笔记,我有疑问。

<javascript语言精粹>是一本很棒的书籍,其中作者在附录列出了12种他所认为的javascript语言中的糟粕. 我最近开始跟读前端前辈的博客,其中读到了阮一峰的<12种不宜使用的Javascript语法>,有一个疑问: 文如下: 9. function语句 在Javascript中定义一个函数,有两种写法: function foo() { } 和 var foo = function () { } 两种写法完全等价.但是在解析的时候,前一种写法会被解析器自动提升到代码的

理解inode - 阮一峰的日志(转载)

作者:阮一峰 一.inode是什么? 理解inode,要从文件储存说起. 文件储存在硬盘上,硬盘的最小存储单位叫做"扇区"(Sector).每个扇区储存512字节(相当于0.5KB). 操作系统读取硬盘的时候,不会一个个扇区地读取,这样效率太低,而是一次性连续读取多个扇区,即一次性读取一个"块"(block).这种由多个扇区组成的"块",是文件存取的最小单位."块"的大小,最常见的是4KB,即连续八个 sector组成一个 b

阮一峰网络日志 第37期 2018年12月28日

http://www.ruanyifeng.com/blog/2018/12/weekly-issue-37.html 声明:链接及文章内容为原博主阮一峰原创. 原文地址:https://www.cnblogs.com/sanen/p/10242378.html

阮一峰网络日志 第38期 2019年01月04日

http://www.ruanyifeng.com/blog/2019/01/weekly-issue-38.html 声明:链接及文章内容为原博主阮一峰原创. 原文地址:https://www.cnblogs.com/sanen/p/10242381.html

阮一峰网络日志 第43期 2019年02月15日

http://www.ruanyifeng.com/blog/2019/02/weekly-issue-43.html 声明:链接及文章内容为原博主阮一峰原创. 原文地址:https://www.cnblogs.com/sanen/p/10390610.html

阮一峰网络日志 第44期 2019年02月22日

http://www.ruanyifeng.com/blog/2019/02/weekly-issue-44.html 声明:链接及文章内容为原博主阮一峰原创. 原文地址:https://www.cnblogs.com/sanen/p/10721366.html

阮一峰网络日志 第65期 (58期--65期)

期数: 58 期      日期:2019-05-31 http://www.ruanyifeng.com/blog/2019/05/weekly-issue-58.html 期数: 59 期      日期:2019-06-07 http://www.ruanyifeng.com/blog/2019/06/weekly-issue-59.html 期数: 60 期      日期:2019-06-14 http://www.ruanyifeng.com/blog/2019/06/weekly-

理解OAuth 2.0 - 阮一峰的网络日志

原文:理解OAuth 2.0 - 阮一峰的网络日志 理解OAuth 2.0 作者: 阮一峰 日期: 2014年5月12日 OAuth是一个关于授权(authorization)的开放网络标准,在全世界得到广泛应用,目前的版本是2.0版. 本文对OAuth 2.0的设计思路和运行流程,做一个简明通俗的解释,主要参考材料为RFC 6749. 一.应用场景 为了理解OAuth的适用场合,让我举一个假设的例子. 有一个"云冲印"的网站,可以将用户储存在Google的照片,冲印出来.用户为了使用

Flex 布局教程:语法篇(转自阮一峰的网络日志)

作者:阮一峰(转自阮一峰的网络日志,如有侵权,立即删除) 网页布局(layout)是 CSS 的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖 display 属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂直居中就不容易实现. 2009年,W3C 提出了一种新的方案----Flex 布局,可以简便.完整.响应式地实现各种页面布局.目前,它已经得到了所有浏览器的支持,这意味着,现在就能很安全地使用这项功能. Flex 布局将成为未来布局的首选方案