自执行功能中的内部变量处理

时间:2015-08-20 08:48:08

标签: javascript this private public

我需要在我的命名空间中使用“私有”和“公共”成员的函数,并且想知道内部发生了什么,因为我无法回溯变量处理。

公共变量“publicVar”应该直接指定为:“myNamespace.publicVar = true”。

var myNamespace = (function() {
    var _privateVar = "not accessible",
        publicVar = false;

    function publicFoo() {
        if (publicVar) {
            console.log("var is true");
        } else {
            console.log("var is false");
        }
    }

    return {
        publicVar: publicVar,
        publicFoo: publicFoo
    }

})();

myNamespace.publicFoo();     // output--> var is false
myNamespace.publicVar = true;
myNamespace.publicFoo();     // output --> var is false
myNamespace.publicVar;       // output--> true of course.

这里发生了什么?为什么我不能以这种方式更改“public”变量,以便正确使用内部? 如果我像这样更改publicFoo()并使用带有“this”的publicVar,它可以正常工作:

    function publicFoo() {
        if (this.publicVar) {
            console.log("var is true");
        } else {
            console.log("var is false");
        }
    }

但我可以避免“这个”吗?或者有更好的方法来处理它吗?

myNamespace.publicFoo();       // output --> var is false
myNamespace.publicVar = true;
myNamespace.publicFoo();       // output --> var is true

非常感谢您的回答。

1 个答案:

答案 0 :(得分:1)

这是因为你说的时候,

myNamespace.publicVar = true;

它在publicVar对象上创建myNamespace它不会更新函数内部的变量。

函数内部的

publicVar是局部的,它只对内部函数可见(图中的闭包)