var dogs = {另一种可以使用此概念的方法是在程序执行期间动态收集属性的名称,如下所示:
Fido:“Mutt”,Hunter:“Doberman”,Snoopie:“Beagle”
};
var myDog =“猎人”;
var myBreed = dogs [myDog];
的console.log(myBreed); //“杜宾犬”
var someObj = {请注意,在使用变量名来访问属性时,我们不会使用引号,因为我们使用的是变量的值 ,而不是名称 。
propName:“约翰”
};
function propPrefix(str){
var s =“prop”;
return s + str;
}
var someProp = propPrefix(“Name”); // someProp现在保存值'propName'
的console.log(someObj中[someProp]); // “约翰”
playerNumber
变量使用括号表示法在testObj
查找玩家16
。然后将该名称分配给player
变量。 playerNumber
应该是一个数字
testString: 'assert(typeof playerNumber === "number", "playerNumber
should be a number");'
- text: 变量player
应该是一个字符串
testString: 'assert(typeof player === "string", "The variable player
should be a string");'
- text: player
的价值应该是“蒙大拿”
testString: 'assert(player === "Montana", "The value of player
should be "Montana"");'
- text: 您应该使用括号表示法来访问testObj
testString: 'assert(/testObj\s*?\[.*?\]/.test(code),"You should use bracket notation to access testObj
");'
- text: 您不应该直接将值Montana
分配给变量player
。
testString: 'assert(!code.match(/player\s*=\s*"|\"\s*Montana\s*"|\"\s*;/gi),"You should not assign the value Montana
to the variable player
directly.");'
- text: 您应该在括号表示法中使用变量playerNumber
testString: 'assert(/testObj\s*?\[\s*playerNumber\s*\]/.test(code),"You should be using the variable playerNumber
in your bracket notation");'
```