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>