zoukankan      html  css  js  c++  java
  • 闭包

    让我们用最简单、直白的话来了解闭包的概念,产生条件、作用等。接下来,我们认识一下:

     1.闭包

    1) 如何产生闭包?
      最常见的方式就是在一个函数内创建另一个函数,通过另一个函数访问这个函数的局部变量

    2) 闭包到底是什么?
       理解一: 闭包是嵌套的内部函数(绝大部分人)
       理解二: 包含被引用变量(函数)的对象(极少数人)

    3) 产生闭包的条件
     1. 函数嵌套
       2. 内部函数引用了外部函数的数据(变量/函数)
       3. 调用外部函数

    eg:

    function fn1 () {
        var a = 3function fn2 () {
            console.log(a)
        }
    }
    fn1()

      fn1,fn2嵌套,fn2引用fn1中变量a;想要执行,还需要调用外部函数fn1

     2. 常见的闭包

       1. 将函数作为另一个函数的返回值

       2. 将函数作为实参传递给另一个函数调用

    1) 示例1

    // 将函数作为另一个函数的返回值

    function fn1() {
      var a = 2
      function fn2() {
        a++
        console.log(a)
      }
      return fn2
    }
    var f = fn1()
    f() // 3
    f() // 4

    2) 示例2
     // 将函数作为实参传递给另一个函数调用

    function showMsg(msg, time) {
      setTimeout(function () {
        console.log(msg)
      }, time)
    }
    showMsg('hello', 1000)

    3. 闭包的作用
    1. 使用函数内部的变量在函数执行完后, 仍然存活在内存中(延长了局部变量的生命周期)
    2. 让函数外部可以操作(读写)到函数内部的数据(变量/函数)
    4. 闭包的声明周期
    1. 产生: 在嵌套内部函数定义执行完时就产生了(不是在调用)
    2. 死亡: 在嵌套的内部函数成为垃圾对象时
    5. 闭包的应用
    定义JS模块:
    1. 具有特定功能的js文件
    2. 将所有的数据和功能都封装在一个函数内部(私有的)
    3. 只向外暴露一个包信n个方法的对象或函数
    4. 模块的使用者, 只需要通过模块暴露的对象调用方法来实现对应的功能

    6. 闭包的缺点
    1. 缺点
    * 函数执行完后, 函数内的局部变量没有释放, 占用内存时间会变长
    * 容易造成内存泄露
    2. 解决
    * 及时释放

     注:一般函数执行完毕后,局部活动对象就被销毁,内存中仅仅保存全局作用域。但闭包的情况不同!

  • 相关阅读:
    jquery ajax
    js 列表选择
    Jquery 搜索框自动提示
    图片居中跟inline-block
    模式学习(一)
    高效图形(一)
    eval() / Function()
    css3(一)
    回调函数(二)
    回调函数(一)
  • 原文地址:https://www.cnblogs.com/renzm0318/p/8810075.html
Copyright © 2011-2022 走看看