2018-10-10 18:03:03 -04:00
---
id: 56533eb9ac21ba0edf2244ca
title: Using Objects for Lookups
challengeType: 1
2019-08-28 16:26:13 +03:00
videoUrl: https://scrimba.com/c/cdBk8sM
forumTopicId: 18373
2018-10-10 18:03:03 -04:00
localeTitle: Использование объектов для поиска
---
## Description
2019-08-28 16:26:13 +03:00
< section id = 'description' >
Объекты можно рассматривать как хранилище ключей / значений, например словарь. Если у вас есть табличные данные, вы можете использовать объект для «поиска», а не для оператора < code > switch< / code > или цепочки < code > if/else< / code > . Это наиболее полезно, когда вы знаете, что ваши входные данные ограничены определенным диапазоном. Вот пример простого обратного алфавитного поиска: < blockquote > var alpha = { < br > 1: " Z" , < br > 2: " Y" , < br > 3: " X" , < br > 4: " W" , < br > ... < br > 24: " С " , < br > 25: " В " , < br > 26: " A" < br > }; < br > альфа [2]; // " Y" < br > альфа [24]; // " C" < br > < br > var value = 2; < br > альфа [значение]; // " Y" < / blockquote >
< / section >
2018-10-10 18:03:03 -04:00
## Instructions
2019-08-28 16:26:13 +03:00
< section id = 'instructions' >
Преобразуйте оператор switch в объект под названием < code > lookup< / code > . Используйте е г о , чтобы посмотреть < code > val< / code > и назначить связанную строку переменной < code > result< / code > .
< / section >
2018-10-10 18:03:03 -04:00
## Tests
< section id = 'tests' >
```yml
tests:
2019-08-28 16:26:13 +03:00
- text: < code > phoneticLookup("alpha")</ code > should equal < code > "Adams"</ code >
testString: assert(phoneticLookup("alpha") === 'Adams');
- text: < code > phoneticLookup("bravo")</ code > should equal < code > "Boston"</ code >
testString: assert(phoneticLookup("bravo") === 'Boston');
- text: < code > phoneticLookup("charlie")</ code > should equal < code > "Chicago"</ code >
testString: assert(phoneticLookup("charlie") === 'Chicago');
- text: < code > phoneticLookup("delta")</ code > should equal < code > "Denver"</ code >
testString: assert(phoneticLookup("delta") === 'Denver');
- text: < code > phoneticLookup("echo")</ code > should equal < code > "Easy"</ code >
testString: assert(phoneticLookup("echo") === 'Easy');
- text: < code > phoneticLookup("foxtrot")</ code > should equal < code > "Frank"</ code >
testString: assert(phoneticLookup("foxtrot") === 'Frank');
- text: < code > phoneticLookup("")</ code > should equal < code > undefined</ code >
testString: assert(typeof phoneticLookup("") === 'undefined');
- text: You should not modify the < code > return</ code > statement
testString: assert(code.match(/return\sresult;/));
- text: You should not use < code > case</ code > , < code > switch</ code > , or < code > if</ code > statements
testString: assert(!/case|switch|if/g.test(code.replace(/([/]{2}.*)|([/][*][^/*]*[*][/])/g,'')));
2018-10-10 18:03:03 -04:00
```
< / section >
## Challenge Seed
< section id = 'challengeSeed' >
< div id = 'js-seed' >
```js
// Setup
function phoneticLookup(val) {
var result = "";
// Only change code below this line
switch(val) {
case "alpha":
result = "Adams";
break;
case "bravo":
result = "Boston";
break;
case "charlie":
result = "Chicago";
break;
case "delta":
result = "Denver";
break;
case "echo":
result = "Easy";
break;
case "foxtrot":
result = "Frank";
}
// Only change code above this line
return result;
}
// Change this value to test
phoneticLookup("charlie");
```
< / div >
< / section >
## Solution
< section id = 'solution' >
```js
2019-08-28 16:26:13 +03:00
function phoneticLookup(val) {
var result = "";
var lookup = {
alpha: "Adams",
bravo: "Boston",
charlie: "Chicago",
delta: "Denver",
echo: "Easy",
foxtrot: "Frank"
};
result = lookup[val];
return result;
}
2018-10-10 18:03:03 -04:00
```
2019-08-28 16:26:13 +03:00
2018-10-10 18:03:03 -04:00
< / section >