对闭包的理解

作者: 86e682d0d2f1 | 来源:发表于2017-08-15 17:31 被阅读30次

一、变量的分类

1、局部变量和全局变量

注意:声明变量时不使用var,所声明的变量就是全局变量,即使是在函数内部声明

的。

二、闭包的定义

1、可以理解为:可以读取其他函数内部变量的函数,

       简单理解为:定义在一个函数内部的子函数。

三、闭包的例子

function f1(){

var n=999;

function f2(){

alert(n);

}

return f2;

}

var result=f1();

result(); // 999

上面的f2就是闭包。

四、闭包的用途

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

五、使用闭包的注意点

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

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

六、思考题

如果你能理解下面两段代码的运行结果,应该就算理解闭包的运行机制了。

代码片段一

var name = "The Window";

var object = {

name : "My Object",

getNameFunc : function(){

return function(){

return this.name;

};

}

};

alert(object.getNameFunc()());

代码片段二

疑惑为什么输出的结果是  “The Window” 。

这是因为代码一中的this代表全局变量。

正确的设计方式是内部函数的 this 应该绑定到其外层函数对应的对象上,为了解决代码一中的缺陷,聪明的 JavaScript 程序员想出了变量替代的方法,约定俗成,该变量一般被命名为 that。

var name = "The Window";

var object = {

name : "My Object",

getNameFunc : function(){

var that = this;

return function(){

return that.name;

};

}

};

alert(object.getNameFunc()());

参考阮一峰的学习Javascript闭包(Closure)

相关文章

  • 【js基础修炼之路】— 深入浅出理解闭包

    之前对于闭包的理解只是很肤浅的,只是浮于表面,这次深究了一下闭包,下面是我对闭包的理解。 什么是闭包? 引用高程里...

  • 对闭包的理解

    一、变量的分类 1、局部变量和全局变量 注意:声明变量时不使用var,所声明的变量就是全局变量,即使是在函数内部声...

  • 闭包(Closure)

    我对闭包的理解 个人理解 : 闭包就是能够读取其他函数内部变量的函数。使用闭包主要是设计私有的方法和变量 优点:可...

  • Gradle开发-Groovy闭包

    # 闭包 闭包的基础知识 闭包的使用 闭包 this,owner,delegate 的理解 总结 ## 闭包的基础...

  • 闭包

    这个问题也是必问的题目.重在把自己对闭包的理解表达出来.而我对闭包的理解是源于很久之前看阮一峰大师讲的闭包(clo...

  • JS进阶系列之闭包

    我对闭包的理解就是:闭包就是能够读取其他函数内部变量的函数,可以把闭包简单理解为“定义在一个函数内部的函数”。 在...

  • Python中的闭包

    php对闭包的定义是匿名函数,我之前对python闭包的理解是:外部函数以内部函数作为返回值,称之为闭包!!!(错...

  • Swift中的逃逸闭包的理解

    逃逸闭包的书面定义:一个传入函数的闭包如果在函数执行结束之后才会被调用,那么这个闭包就叫做逃逸闭包。 对定义的理解...

  • 我对闭包的理解

    总结一句话:让一个局部变量能被外部环境引用到,从而这个局部变量不会被垃圾回收,就形成了闭包。先上代码,一个最简单的...

  • 我对闭包的理解

    闭包:从字面意思来理解就是封闭和包裹,换句话说,就是在函数内部定义的变量,在函数的外部无法访问到,因此就说函数构成...

网友评论

    本文标题:对闭包的理解

    本文链接:https://www.haomeiwen.com/subject/badvrxtx.html