如何访问动态局部变量

时间:2011-04-29 15:24:12

标签: javascript variables dynamic scope local-variables

我如何引用动态局部变量?这可以通过全局变量轻松完成:

myPet = "dog";  
console.log(window["myPet"]);

我如何在本地范围内做同样的事情?


特别是我正在尝试做的事情:

myArray = [100,500,200,800];  
a = 1; // Array index (operand 1)  
b = 2; // Array index (operand 2)  

根据具体情况,我想评估 a< b或b< a

  • 为实现这一目标,我设置了两个变量: compare1 compare2
  • compare1将引用 a b ,compare2将引用其他
  • 评估 compare1 < compare2 或反之亦然

以下内容适用于全局变量。但是,我希望 a b 是本地的。

compare1 = "b"; compare2 = "a";  
for(a=0; a<myArray.length; a++){  
  b = a+1;  
  while(b>=0 && myArray[window[compare1]] < myArray[[compare2]]){    
    /* Do something; */
    b--;  
  }
}  

如果在上面我设置了compare1=a,那么每次 a 更改时我都必须重置 compare1 。相反,我想实际[看/指向] a 的价值。

3 个答案:

答案 0 :(得分:4)

使用对象而不是一组单独的变量。 (我想不出一个真实世界的情况,你想要使用一个动态命名的变量,它不是一组逻辑相关的变量的一部分。)

var animals = { dog: "Rover", cat: "Flopsy", goldfish: "Killer" };
var which = 'dog';
alert(animals[which]);

答案 1 :(得分:1)

如果函数返回了局部变量,则可以全局引用它。

function dog(name) {

  var local = name;

  return local;

}

myPet = dog('spike');

alert(myPet);

答案 2 :(得分:1)

您可以使用eval完成此操作,但强烈建议不要使用eval。如果你能满足大卫多尔沃德的建议,我会这样做:

var myPet = 'dog';
var dog = 'fido';

eval("alert(" + myPet + ")");  // alerts "fido"