码迷,mamicode.com
首页 > 其他好文 > 详细

理解闭包

时间:2019-03-04 21:09:07      阅读:203      评论:0      收藏:0      [点我收藏+]

标签:私有   计数   回收机制   src   private   div   ret   name   失效   

1:什么是闭包?

闭包就是函数嵌套函数 ,定义在一个函数内部的函数 能够读取其他函数内部变量的函数 ,本质上闭包就是将函数内部与外部连接起来的桥梁

 

2:学习闭包之前需要从哪考虑

2.1变量的作用域:全局变量和局部变量

由于函数内部可以读取全局变量  但是外部却不能读取函数内的局部变量  函数内部声明变量的时候,一定要用var。如果不用的话,就是全局变量

所以如果想获得函数内的局部变量需要在函数内再定义一个函数

技术图片
f1是父函数,f2是字函数 f2被赋给了一个全局变量,这导致f2始终在内存中 ,f2又依赖于f1,f1也被保存在内存中

 

3:闭包的应用(为什么要用)

3.1:外部获取内部局部变量

3.2:避免全局污染

3.3:自执行的匿名函数保存循环变量

4:闭包的缺点和注意点

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

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

3)闭包与闭包之间要用分号;互不影响

5:如何调用闭包里的函数

把对象和方法赋值给window下,用 window.xxx=xxx

6:垃圾回收机制造成的内存泄漏问题

计数器跟踪变量 变量为0的时候就会被废弃回收  如果变量一直被保存不被回收就会为1  垃圾回收机制就会失效

如果变量a不再被引用,就会被回收,如果a和b互相引用,但是不再被c引用,也会被回收 ,如果a被b引用,b又被a之外的c引用,就不会被回收

7:再拿阮老师的两道题

代码一:var name = "The Window";

  var object = {
    name : "My Object",

    getNameFunc : function(){
      return function(){
        return this.name;
      };

    }

  };

  alert(object.getNameFunc()());

代码二:

var name = "The Window";

  var object = {
    name : "My Object",

    getNameFunc : function(){
      var that = this;
      return function(){
        return that.name;
      };

    }

  };

  alert(object.getNameFunc()());

理解闭包

标签:私有   计数   回收机制   src   private   div   ret   name   失效   

原文地址:https://www.cnblogs.com/senlin1314/p/10472758.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!