zoukankan      html  css  js  c++  java
  • js闭包

    闭包:当内部函数 在定义它的作用域 的外部 被引用时,就创建了该内部函数的闭包 ,如果内部函数引用了位于外部函数的变量,当外部函数调用完毕后,这些变量在内存不会被 释放,因为闭包需要它们.


    <p>局部变量计数。</p>
    <button type="button" onclick="myFunction()">计数!</button>
    <p id="demo">0</p>

    var add = (function () {
        var counter = 0;
        function innerFun(){
            counter +=1;
            return counter;
        }    
        return innerFun;
    })();
    function myFunction(){
        document.getElementById("demo").innerHTML = add();
    }


    <p>局部变量计数。</p>
    <button type="button" onclick="myFunction()">计数!</button>
    <p id="demo">0</p>

    var add = (function out() {
        var counter = 0;
        function innerFun(){
            counter +=1;
            return counter;
        }    
        return innerFun;
    })();
    function myFunction(){
        document.getElementById("demo").innerHTML = add();
    }
    函数out()是函数innerFun()父函数,innerFun被赋给了一个全局变量,导致innerFun始终在内存中,innerFun依赖于out,所以out也始终存在于内存中,不会再out调用结束后被垃圾回收,counter也一直存在内存中。


    注意:

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

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

  • 相关阅读:
    linux 命令
    Linux中zip压缩和unzip解压缩命令详解
    Sublime Text2.0.2注册码
    Yii框架入门教程(博客教程、权威指南、类手册)
    Redis在PHP中的基本使用案例
    Yii MemCache 应用实例
    javascript数组操作汇总
    CSS进阶学习
    暑期周总结八(2018.8.27-2018.9.2)
    3D轮播图
  • 原文地址:https://www.cnblogs.com/0914lx/p/7878651.html
Copyright © 2011-2022 走看看