当前位置 主页 > 服务器问题 > win服务器问题汇总 >

    Javascript闭包实例详解(3)

    栏目:win服务器问题汇总 时间:2019-12-02 10:07

    testList的执行结果是弹出item3 undefined窗口三次,因为这三个函数绑定了同一个闭包,而且item的值为最后计算的结果,但是当i跳出循环时i值为4,所以list[4]的结果为undefined.

    例子4:外部函数所有局部变量都在闭包内,即使这个变量声明在内部函数定义之后。

    function sayAlice() {
      var sayAlert = function() { alert(alice); }
      // Local variable that ends up within closure
      var alice = 'Hello Alice';
      return sayAlert;
    }
    var helloAlice=sayAlice();
    helloAlice();

    执行结果是弹出”Hello Alice”的窗口。即使局部变量声明在函数sayAlert之后,局部变量仍然可以被访问到。

    例子5:每次函数调用的时候创建一个新的闭包

    function newClosure(someNum, someRef) {
      // Local variables that end up within closure
      var num = someNum;
      var anArray = [1,2,3];
      var ref = someRef;
      return function(x) {
        num += x;
        anArray.push(num);
        alert('num: ' + num +
        '\nanArray ' + anArray.toString() +
        '\nref.someVar ' + ref.someVar);
      }
    }
    closure1=newClosure(40,{someVar:'closure 1'});
    closure2=newClosure(1000,{someVar:'closure 2'});
    closure1(5); // num:45 anArray[1,2,3,45] ref:'someVar closure1'
    closure2(-10);// num:990 anArray[1,2,3,990] ref:'someVar closure2'

    闭包的应用

    Singleton 单件:

    var singleton = function () {
      var privateVariable;
      function privateFunction(x) {
        ...privateVariable...
      }
      return {
        firstMethod: function (a, b) {
          ...privateVariable...
        },
        secondMethod: function (c) {
          ...privateFunction()...
        }
      };
    }();

    这个单件通过闭包来实现。通过闭包完成了私有的成员和方法的封装。匿名主函数返回一个对象。对象包含了两个方法,方法1可以方法私有变量,方法2访 问内部私有函数。需要注意的地方是匿名主函数结束的地方的'()',如果没有这个'()'就不能产生单件。因为匿名函数只能返回了唯一的对象,而且不能被 其他地方调用。这个就是利用闭包产生单件的方法。