Se si desidera utilizzare le funzioni globali e variabili in modo dinamico è possibile utilizzare:Come posso accedere dinamicamente all'ambito locale in javascript?
window[functionName](window[varName]);
E 'possibile fare la stessa cosa per le variabili in ambito locale?
Questo codice funziona correttamente ma attualmente utilizza eval e sto cercando di pensare a come altro farlo.
var test = function(){
//this = window
var a, b, c; //private variables
var prop = function(name, def){
//this = window
eval(name+ ' = ' + (def.toSource() || undefined) + ';');
return function(value){
//this = test object
if (!value) {
return eval('(' + name + ')');
}
eval(name + ' = value;')
return this;
};
};
return {
a:prop('a', 1),
b:prop('b', 2),
c:prop('c', 3),
d:function(){
//to show that they are accessible via to methods
return [a,b,c];
}
};
}();
>>>test
Object
>>>test.prop
undefined
>>>test.a
function()
>>>test.a()
1 //returns the default
>>>test.a(123)
Object //returns the object
>>>test.a()
123 //returns the changed private variable
>>>test.d()
[123,2,3]
Ottengo il motivo per cui ero confuso ora, è perché stai nominando le variabili abc così come i nomi per il ritorno. Dovresti cambiare quei nomi, è questo che mi stava confondendo. Ad ogni modo, le risposte migliori della mia si sono rivelate, quindi mi limiterò a rimandare a crescentfresh a questo punto. –
@ Gothdo La domanda a cui ti colleghi sta chiedendo qualcosa di diverso. Le variabili a cui sta tentando di accedere sono variabili globali. La risposta accettata utilizza anche variabili globali. La domanda collegata dovrebbe essere cambiata. – Annan