闭包

什么是闭包? 

 

官方对闭包的解释是:一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分

 

闭包的特点:
  1.作为一个函数变量的一个引用,当函数返回时,其处于激活状态。
  2.一个闭包就是当一个函数返回时,一个没有释放资源的栈区。
简单的说,javascript允许使用内部函数---即函数定义和函数表达式位于另一个函数的函数体内。
而且,这些内部函数可以访问它们所在的外部函数中声明的所有局部变量、参数和声明的其他内部函数。
当其中一个这样的内部函数在包含它们的外部函数之外被调用时,就会形成闭包。

   

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<script type="text/javascript" src="../js/vue.js"></script>
<body>

</body>

<script type="text/javascript">
    //平常创建的方式
    //一个函数包含另一个函数,内部函数使用外部函数的变量或者参数。
    function myFunction() { var x = 10; return function() { x++; alert(x); } } var a = myFunction(); a(); //11
 a(); //12
 a(); //13
    //闭包可以使一个局部的变量或者参数不会被回收,以便我们长期的使用。
</script>

</html>

一、变量的作用域
要理解闭包,首先必须理解Javascript特殊的变量作用域。
变量的作用域无非就是两种:全局变量和局部变量。
Javascript语言的特殊之处,就在于函数内部可以直接读取全局变量。

 

var n=999;
  function f1(){
    alert(n);
  }
  f1(); // 999

 

另一方面,在函数外部自然无法读取函数内的局部变量。

function f1(){
    var n=999;
  }
  alert(n); // error

 二、如何从外部读取局部变量?

那就是在函数的内部,再定义一个函数。
  function f1(){
    var n=999;
    function f2(){
      alert(n); // 999
    }
  }

 

 

总结:

  1. 总结:如果想要缓存数据,就把这个数据放在外层的函数和里层的函数的中间位置
  2. 闭包的作用:缓存数据.优点也是缺陷,没有及时的释放
  3. 局部变量是在函数中,函数使用结束后,局部变量就会被自动的释放
  4. 闭包后,里面的局部变量的使用作用域链就会被延长
posted @ 2020-02-27 09:21  布局  阅读(50)  评论(0)    收藏  举报