js中的闭包

xiaoxiao2021-02-28  24

function outerFunction(){

              var a = 0;

             function innerFunction(){

                   a++;

                   alert(a);

           }

}

innerFunction();

这样写是错误的,因为innerFunction()的作用域在outerFunction()函数的内部,所以在outerFunction()外部调用它是错误的,改成如下闭包形式

function outerFunction() {       var temp = 0;       function innerFunction(){            temp++;            console.log(temp);       }       return innerFunction; }

var result = outerFunction();

result();//1

result();//2

var result2 = outerFunction();

result2();//1

result2();//2

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

再看一个例子:

function outerFunction(){      var a = 0;      alert(a);

}

var a = 4; outerFunction();//0 alert(a);//4

此时输出0   4,这是因为在outerFunction()函数内部声明a时使用的var,所以声明的是一个局部变量,维护a的作用域在outerFunction()内部

再看下面的例子:

 

function outerFunction(){      a = 0;      alert(a);

}

var a = 4; outerFunction();//0 alert(a);//0

此时输出的结果是0 0,这是因为在outerFunction()函数内部声明的a是全局变量,因此赋值操作会沿着作用域链到var a=4;  并改变其值.

 

使用闭包的最大用处有两个,一个是可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中。

如何使用闭包:

 

定义外层函数,封装被保护的局部变量。定义内层函数,执行对外部函数变量的操作。外层函数返回内层函数的对象,并且外层函数被调用,结果保存在一个全局的变量中。

 

 

 

转载请注明原文地址: https://www.6miu.com/read-2250000.html

最新回复(0)