编程语言
首页 > 编程语言> > javascript – 如何访问动态局部变量

javascript – 如何访问动态局部变量

作者:互联网

我如何引用动态局部变量?使用全局变量很容易实现:

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

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

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

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

根据情况,我想评估< b或b< a
>为此,我设置了两个变量:compare1和compare2
> compare1将引用a或b,compare2将引用另一个
>评估compare1<比较2,反之亦然
以下与全局变量完美配合.但是,我希望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,那么每次更改时我都必须重置compare1.相反,我想实际[看/指向]的价值.

解决方法:

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

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

标签:javascript,scope,dynamic,variables,local-variables
来源: https://codeday.me/bug/20190518/1128290.html