提前感谢任何帮助的人:)。
对于那些有经验的人来说,这似乎是一个简单的答案,但我在互联网上搜索了几本参考书,并没有找到这个问题的直接答案,所以希望它也能对其他人有所帮助。
我目前正在从 Actionscript 过渡到 Typescript,并且对普通 Javascript 有相当多的经验,所以简单地用 Javascript 术语来说,如果我想动态引用一个变量,我可以简单地使用这样的东西:
var myTextA = "Hello!";
var myTextB = "Goodbye!";
var textList = ["A", "B"];
console.log("I want to say " + this["myText" + textList[0]]);
结果当然会是:"我想说你好!
在 Typescript 中,对于类中的私有变量,这似乎是不可能的,并导致以下 TSC 错误:
"Index signature of object type implicitly has an 'any' type."
据我所知,打字稿希望我在动态结构中以某种方式声明变量类型,但是我找不到有关如何执行此操作的任何明确参考。
出于我自己的目的,为了将其置于上下文中,我正在从事一个项目,我需要循环访问一系列配对变量,这些变量都具有相同的开头,但结尾略有不同,因此简单地将变量本身放在数组中不是一种选择(或者无论如何,这将是一个混乱的解决方案)。
例如:
var myVar1a, myVar1b, myVar2a, myVar2b etc...
所以在循环中,我想同时引用每个的 a 和 b:
console.log(this["myVar" + (i+1) + "a");
console.log(this["myVar" + (i+1) + "b");
任何帮助都非常感谢!!
我建议使用面向对象的"类型化"方法。毕竟,这就是为什么你可能想使用打字稿而不是javascript。因此,在打字稿中,您将按以下方式执行此操作。要赋予"this"以意义,您必须在某个类中引用它。如果你的情况,它可能看起来像这样:
class Test
{
private myTextA = "Hello!";
private myTextB = "Goodbye!";
private textList = ["A", "B"];
public callMe()
{
console.log("I want to say " + this["myText" + this.textList[0]]);
}
}
console.log((new Test()).callMe());
据我所知,打字稿希望我在动态结构中以某种方式声明变量类型,但是我找不到有关如何执行此操作的任何明确参考。
您需要指定index
签名。 例如:
// Here you are saying that map is something that when accessed by a string returns a string
var map: {[key:string]:string} = {};
map['myTextA'] = "Hello!";
map['myTextB'] = "Goodbye!";
var textList = ["A", "B"];
console.log("I want to say " + map["myText" + textList[0]]);