Files

110 lines
2.3 KiB
Markdown
Raw Permalink Normal View History

---
id: 5690307fddb111c6084545d7
title: if else ステートメントの論理的順序
challengeType: 1
videoUrl: 'https://scrimba.com/c/cwNvMUV'
forumTopicId: 18228
dashedName: logical-order-in-if-else-statements
---
# --description--
`if` ステートメント、`else if` ステートメントでは、順序が重要です。
関数は上から下へと実行されるので、どのステートメントが先に来るかに気をつけるようにしてください。
例として 2 つの関数を考えてみましょう。
まず 1 つ目です。
```js
function foo(x) {
if (x < 1) {
return "Less than one";
} else if (x < 2) {
return "Less than two";
} else {
return "Greater than or equal to two";
}
}
```
2 つ目は 1 つ目のステートメントの順序を入れ替えただけのものです。
```js
function bar(x) {
if (x < 2) {
return "Less than two";
} else if (x < 1) {
return "Less than one";
} else {
return "Greater than or equal to two";
}
}
```
これら 2 つの関数は見かけはほとんど同じですが、両方に数値を渡すと異なる出力が得られます。
```js
foo(0)
bar(0)
```
`foo(0)` は文字列 `Less than one` を返し、`bar(0)` は文字列 `Less than two` を返します。
# --instructions--
すべてのケースで適切なステートメントを返すように、関数内のロジックの順序を変更してください。
# --hints--
`orderMyLogic(4)` は文字列 `Less than 5` を返す必要があります。
```js
assert(orderMyLogic(4) === 'Less than 5');
```
`orderMyLogic(6)` は文字列 `Less than 10` を返す必要があります。
```js
assert(orderMyLogic(6) === 'Less than 10');
```
`orderMyLogic(11)` は文字列 `Greater than or equal to 10` を返す必要があります。
```js
assert(orderMyLogic(11) === 'Greater than or equal to 10');
```
# --seed--
## --seed-contents--
```js
function orderMyLogic(val) {
if (val < 10) {
return "Less than 10";
} else if (val < 5) {
return "Less than 5";
} else {
return "Greater than or equal to 10";
}
}
orderMyLogic(7);
```
# --solutions--
```js
function orderMyLogic(val) {
if(val < 5) {
return "Less than 5";
} else if (val < 10) {
return "Less than 10";
} else {
return "Greater than or equal to 10";
}
}
```