javascript 闭包问题,为什么要写成闭包的形式?

我看闭包是为了能让外部得到函数内部定义的局部变量。
那为什么一定要写成这样的形式呢?

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

就直接return 不行么?像这样

function f1(){
    var n=123;
    return n;
}
x=f1();
alert(x);  ///123

这也是闭包么?

阅读 7.8k
7 个回答

首先,第二个肯定不是闭包,闭包是一个函数。
闭包一般用来隐藏或说保护我们的一些成员变量,通过闭包的形式返回出去一个能够操作我们保护起来的成员变量的函数。

    function f1(){
    var n=999;
    function f2(){
      alert(n++);
    }
    return f2;
  }
  var result=f1();
  result(); // 999
    result();// 1000
像上面这样,我们就能够访问f1的私有变量n,并且只能用每次+1的方式进行操作,一般来说闭包的使用像下面这样:
    var car = (function(){
            var _wheels = 4;

            return {
                setWheels : function(value){
                    if (value < _wheels) {
                      throw new Error('数值太小了!');
                    }
                    _wheels = value;
                },
                getWheels : function(){
                    return _wheels;
                }
            }

        })();
我们给汽车轮子数量赋值的时候,是要调用set方法的,是不能随便赋值的。
如果像你第二张方式写的:
function f1(){
    var obj={age : 10};
    return obj;
}
obj=f1();
obj.age = -100;
我们是不是把年龄赋值成-100了

后者不是闭包。
简单的说,闭包就是能够读取其他函数内部变量的函数

function f1(){
    var n=123;
    return n;
}
x=f1(); //返回的是一个值,这个值始终是123,无法改变
alert(x);  ///123

如果把第一个例子改成这样的形式

function f1(){

    var n= 999;
    var obj= {};
    obj.f2 = function(){
        console.log(n);
    }
    obj.add = function () {
        n++
    }
    return obj;
}
var result=f1();


result.f2(); // 999
result.add();
result.f2();//1000

这里返回的result可以即时的访问和修改f1里的变量n,
除了这种方法之外,外部没有方法可以改变n的值,相当于定义了一个特权方法。这就是闭包的作用,体会一下。

直接return出去是一个变量,而闭包是返回的一个执行环境。。。

楼主的理解有点狭隘了,
1,闭包不是为了让函数外部拿到内部变量。而是为了保护私有变量

2,return出来的是一个值,不是变量本身,此处的return是取得私有变量值的一种方法,跟闭包没有严格关系

首先你要理解闭包是什么? 说简单点就是一个函数,只是通过这个函数 可以在函数的外部去访问函数内部的变量。

return 变量,只是返回值,我想问楼主如果想引用内部变量怎么办?

新手上路,请多包涵

看来你没有明白闭包的定义。

我的理解是:函数对其词法环境的引用 的组合。常用来间接地访问一个变量。当函数可以记住并访问所在的词法作用域,即使函数是在当前词法作用域之外执行,这时就产生了闭包。

详细深入理解可以看下我的文章javaScript中的闭包

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题