zoukankan      html  css  js  c++  java
  • JS中的闭包

    闭包

         最近在Js的高三的书,看到闭包那块,感觉比较重要,特地记录一下。

         闭包:指有权访问另一个函数作用域中变量的函数,一般形式是函数中嵌套函数,内部函数可以访问外部函数作用域中的变量。

         闭包的产生:当函数被调用时,立即创建函数的执行环境和作用域链,【作用域是指向变量对象列表,他只引用却不包含任何变量对象】,最内层的匿名函数的作用域链包含了上层的活动对象和全局变量对象,当活动对象函数执行完成后,他的作用域链被销毁了,但是他的活动对象依然存在,因为匿名函数仍在引用着,只有匿名函数执行完成后,才会被销毁

         function CreateComparisonFunction(propertyName) {
                        return function (object1, object2) {
                            var val1 = object1[propertyName];
                            var val2 = object2[propertyName];
                            if (val1 > val2) return 1;
                            if (val1 < val2) return -1;
                            return 0;
                        }
                    }
    
                    var dataFunction = CreateComparisonFunction("age");
                    var val = dataFunction({ age: 16 }, { age: 15 });

      此函数的执行过程如下图所示:

         

          

            另外还有一个比较经典关于闭包的例子

             

               function CreateArray() {
                        var arr = new Array();
                        for (var i = 0; i < 10; i++) {
                            arr[i] = function () {
                                return i;
                            }
                        }
                        return arr;
    
                    }
    

       以上代码当函数执行完毕后,此时变量i为10,在内部每个函数都引用着保存着变量i的对象,所以每个函数的i都为10,此时可通过闭包实现让每个函数独立包含不用的引用对象

            function CreateArray() {
                var arr = new Array();
                for (var i = 0; i < 10; i++) {
                    arr[i] = function (num) {
                        return function () { return num; }
                    } (i)
                };
                return arr;
    
            }
    

          

        

  • 相关阅读:
    闭包 (Closure)
    RSA算法
    HTTPS
    SSH
    HDU1754 I hate it_线段树(入门级别)
    HDU1166 敌兵布阵_线段树
    c++运算符优先级表
    归并排序练习.
    HDU 1969 精度二分
    uva10944 状态压缩bfs or DP
  • 原文地址:https://www.cnblogs.com/JaggerMan/p/4394690.html
Copyright © 2011-2022 走看看