Tim*_*ich 11 javascript module-pattern
有没有办法从模块模式中动态访问私有变量的公共函数?test1显示了我对"动态访问"的含义,但使用了公共变量
var x = (function(){
var x=0, y=2, z=5;
return {
toast: 123,
test1: function(arg){
return this[arg];
},
test2: function(){
// ??
}
};
}());
console.log(x.test1("toast")); // 123
console.log(x.test2("y")); // should return 2
Run Code Online (Sandbox Code Playgroud)
我最终创建了一个存储我的私有变量的私有变量(一个对象),所以我能够像这样访问它们
privateVarStore[privateVarName]
Run Code Online (Sandbox Code Playgroud)
但是有另一种解决方案吗?
是.
很抱歉让Adam Rackis失望,但你可以用(邪恶的)eval 做到这一点:
var x = (function(){
var x=0, y=2, z=5;
return {
toast: 123,
test1: function(arg){
return this[arg];
},
test2: function(a){
return eval(a)
}
};
}());
console.log(x.test1("toast")); // 123
console.log(x.test2("y")); // should return 2 -> does return 2
Run Code Online (Sandbox Code Playgroud)
这是eval应该使用的少数例外之一.
编辑,根据Hans B PUFAL建议(评论),您可以并且应该test2如下验证参数:
test2: function(a){
return /^[$_a-z][$_a-z0-9]*$/i.test (a) ? eval(a) : undefined;
}
Run Code Online (Sandbox Code Playgroud)
不(至少不是没有诉诸eval,根据qwertymk的回答).
y(不x考虑将此对象命名为比x避免与局部变量混淆更好的属性x). y是一个局部变量,其x方法形成了一个闭包.
任何x方法都可以访问y,但不能通过说this.y,而是通过y直接访问.
同样,y不是您对象的属性x.它只是创建函数中的局部变量x,从而导致x方法在其上形成闭包.
所以,要test2回归y,只需:
test2: function(){
return y;
}
Run Code Online (Sandbox Code Playgroud)
要创建允许您访问私有变量的方法,请考虑以下内容:
var x = (function () {
var privateMembers = { x: 0, y: 2, z: 5 };
return {
getPrivate: function (name) {
return privateMembers[name];
},
toast: 123,
test1: function (arg) {
return this[arg];
},
test2: function () {
// ??
}
};
})();
Run Code Online (Sandbox Code Playgroud)
然后
alert(x.getPrivate("y")); //alerts 2
Run Code Online (Sandbox Code Playgroud)
看看这个小提琴