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


    【闭包】:就是能够读取其他函数内部变量的函数(声明这个函数为变量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

  • 相关阅读:
    五分钟,让你明白MySQL是怎么选择索引《死磕MySQL系列 六》 咔咔
    MySQL统计总数就用count(*),别花里胡哨的《死磕MySQL系列 十》 咔咔
    C++类型转换:const_cast 和reinterpret_cast
    C++类型转换
    C++中*和&的用法
    CMake简介
    文件和流IO
    字节存储:大端字节和小端字节
    离线的Window 10无法安装.Net Framework 3.5的解决办法
    KeyTool 使用简介
  • 原文地址:https://www.cnblogs.com/wheatCatcher/p/8508918.html
Copyright © 2020-2023  润新知