理解闭包的含义以及他的使用

Posted 秋水涴晴汐

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了理解闭包的含义以及他的使用相关的知识,希望对你有一定的参考价值。

1、什么是闭包,
  闭包就是能够读取其它函数内部的变量。

首先我们来看一段代码:
function a(){ var n = 0; function inc() { n++; console.log(n); } inc(); inc(); } a(); //控制台输出1,再输出2

再来看一段代码:
function a(){
    var n = 0;
    this.inc = function () {
        n++; 
        console.log(n);
    };
}
var c = new a();
c.inc();    //控制台输出1
c.inc();    //控制台输出2

这就是闭包,是不是很简单!

这里 inc 函数访问了构造函数 a 里面的变量 n,所以形成了一个闭包。再来看一段代码:

function a(){
    var n = 0;
    function inc(){
       n++; 
console.log(n); } return inc; } var c = a(); c(); //控制台输出1 c(); //控制台输出2

看看是怎么执行的:

var c = couter(),这一句 couter()返回的是函数 inc,那这句等同于 var c = inc; 

c(),这一句等同于 inc();  注意,函数名只是一个标识(指向函数的指针),而()才是执行函数。

后面三句翻译过来就是:  var c = inc;  inc();  inc();,跟第一段代码没有区别。

以上是关于理解闭包的含义以及他的使用的主要内容,如果未能解决你的问题,请参考以下文章

js闭包理解

Python_基础个人理解_闭包

JavaScript 闭包

理解C#中的闭包

20170815 前端开发日报

javascript之闭包理解以及应用场景