JavaScript闭包

2021/7/26 11:05:39

本文主要是介绍JavaScript闭包,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

JavaScript闭包(Closure)

1.应用背景

闭包是JavaScript语言的难点,但是在很多高级的应用中都会存在

2.变量的作用域

JavaScript中的变量无非两种,局部变量和全局变量

局部变量:位于代码块的内部,并仅限于当前的函数使用,当当前的对象被销毁的时候,该变量也会在内存中被销毁.

全局变量:位于代码块的外部,内容与局部变量相反.

注意:使用内部的变量的时候,一定要使用限定词 let/var 不然,你实际在内部定义了一个全局变量.

function f1(){
    n=999;
  }
  f1();
  alert(n); // 999
3.从外部读取局部变量(闭包的理解)

​ JavaScript就是通过再函数的内部再定义一个函数,从而获取该函数局部变量的方式.

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

var result=f1();
result(); //999
4.使用闭包的注意点(引用阮一峰的闭包)

https://www.ruanyifeng.com/blog/2009/08/learning_javascript_closures.html

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

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



这篇关于JavaScript闭包的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程