freeCodeCamp/curriculum/challenges/japanese/02-javascript-algorithms-an.../basic-javascript/using-objects-for-lookups.md

156 lines
3.5 KiB
Markdown
Raw Normal View History

---
id: 56533eb9ac21ba0edf2244ca
title: オブジェクトを使用してルックアップ検索を行う
challengeType: 1
videoUrl: 'https://scrimba.com/c/cdBk8sM'
forumTopicId: 18373
dashedName: using-objects-for-lookups
---
# --description--
オブジェクトは、辞書のようなキー/値の保管場所と捉えることができます。 表形式のデータがある場合、`switch` ステートメントや `if/else` のチェーンを使用せずに、オブジェクトを利用して値のルックアップ検索を行うことができます。 この方法は、入力データが特定の範囲に制限されていることがわかっている場合に特に便利です。
単純な逆アルファベット順のルックアップ検索の例を次に示します。
```js
const alpha = {
1:"Z",
2:"Y",
3:"X",
4:"W",
...
24:"C",
25:"B",
26:"A"
};
const thirdLetter = alpha[2];
const lastLetter = alpha[24];
const value = 2;
const valueLookup = alpha[value];
```
`thirdLetter` は文字列 `Y`、`lastLetter` は文字列 `C`、`valueLookup` は文字列 `Y` となります。
# --instructions--
switch ステートメントを `lookup` という名前のオブジェクトに変換してください。 オブジェクトを利用して `val` をルックアップ検索し、関連する文字列を `result` 変数に代入してください。
# --hints--
`phoneticLookup("alpha")` は文字列 `Adams` と等しくなる必要があります。
```js
assert(phoneticLookup('alpha') === 'Adams');
```
`phoneticLookup("bravo")` は文字列 `Boston` と等しくなる必要があります。
```js
assert(phoneticLookup('bravo') === 'Boston');
```
`phoneticLookup("charlie")` は文字列 `Chicago` と等しくなる必要があります。
```js
assert(phoneticLookup('charlie') === 'Chicago');
```
`phoneticLookup("delta")` は文字列 `Denver` と等しくなる必要があります。
```js
assert(phoneticLookup('delta') === 'Denver');
```
`phoneticLookup("echo")` は文字列 `Easy` と等しくなる必要があります。
```js
assert(phoneticLookup('echo') === 'Easy');
```
`phoneticLookup("foxtrot")` は文字列 `Frank` と等しくなる必要があります。
```js
assert(phoneticLookup('foxtrot') === 'Frank');
```
`phoneticLookup("")``undefined` になる必要があります。
```js
assert(typeof phoneticLookup('') === 'undefined');
```
`return` ステートメントを変更しないでください。
```js
assert(code.match(/return\sresult;/));
```
`case` ステートメント、`switch` ステートメント、`if` ステートメントを使用しないでください。
```js
assert(
!/case|switch|if/g.test(code.replace(/([/]{2}.*)|([/][*][^/*]*[*][/])/g, ''))
);
```
# --seed--
## --seed-contents--
```js
// Setup
function phoneticLookup(val) {
let 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;
}
phoneticLookup("charlie");
```
# --solutions--
```js
function phoneticLookup(val) {
let result = "";
const lookup = {
alpha: "Adams",
bravo: "Boston",
charlie: "Chicago",
delta: "Denver",
echo: "Easy",
foxtrot: "Frank"
};
result = lookup[val];
return result;
}
```