--- id: 587d7b7c367417b2b2512b1a challengeType: 1 forumTopicId: 301150 localeTitle: 使用方括号访问属性名称 --- ## Description
在关于对象的第一个挑战中,我们提到可以在方括号符号中用一个变量作为属性名来访问属性值。假设一个超市的收银台的程序中使用了一个foods对象,并且有一些程序逻辑会设置selectedFood,我们需要查询foods对象来检查某种食物是否存在,我们可以这样写检查逻辑: ```js let selectedFood = getCurrentFood(scannedItem); let inventory = foods[selectedFood]; ``` 上述代码会先计算selectedFood变量的值,并返回foods对象中以该值命名的属性对应的值,若没有以该值命名的属性则会返回undefined。有时候对象的属性名在运行之前是不确定的,或者我们需要动态地访问对象的属性,这时方括号符号就会很有用。
## Instructions
我们已经定义了一个checkInventory函数,它接受一个被扫描到的商品名作为输入参数。它要返回foods对象中以scannedItem的值命名的属性的值。只有有效的属性名会作为参数传入checkInventory,你在完成挑战时不需处理参数无效的情况。
## Tests
```yml tests: - text: checkInventory是一个函数 testString: assert.strictEqual(typeof checkInventory, 'function'); - text: 'foods对象应该只有以下键值对: apples: 25oranges: 32plums: 28bananas: 13grapes: 35strawberries: 27' testString: 'assert.deepEqual(foods, {apples: 25, oranges: 32, plums: 28, bananas: 13, grapes: 35, strawberries: 27});' - text: checkInventory("apples")应该返回25 testString: assert.strictEqual(checkInventory('apples'), 25); - text: checkInventory("bananas")应该返回13 testString: assert.strictEqual(checkInventory('bananas'), 13); - text: checkInventory("strawberries")应该返回27 testString: assert.strictEqual(checkInventory('strawberries'), 27); ```
## Challenge Seed
```js let foods = { apples: 25, oranges: 32, plums: 28, bananas: 13, grapes: 35, strawberries: 27 }; // do not change code above this line function checkInventory(scannedItem) { // change code below this line } // change code below this line to test different cases: console.log(checkInventory("apples")); ```
## Solution
```js // solution required let foods = { apples: 25, oranges: 32, plums: 28, bananas: 13, grapes: 35, strawberries: 27 }; function checkInventory(scannedItem) { return foods[scannedItem]; } ```