• 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;
    
            }
    

          

        

  • 相关阅读:
    Python Scrapy环境配置教程+使用Scrapy爬取李毅吧内容
    Python 基础语法+简单地爬取百度贴吧内容
    Hadoop Mapreduce 工作机制
    Myeclipse 配置Git详解
    Java 多线程详解
    Hadoop Mapreduce 案例 wordcount+统计手机流量使用情况
    Hadoop HDFS NameNode工作机制
    Hadoop HDFS元数据目录分析
    Hadoop HDFS DataNode 目录结构
    Hadoop HDFS 文件块大小
  • 原文地址:https://www.cnblogs.com/JaggerMan/p/4394690.html
Copyright © 2020-2023  润新知