2018-10-10 22:03:03 +00:00
|
|
|
|
---
|
|
|
|
|
id: 56533eb9ac21ba0edf2244dd
|
2021-03-15 03:20:39 +00:00
|
|
|
|
title: 使用 Switch 语句从许多选项中进行选择
|
2018-10-10 22:03:03 +00:00
|
|
|
|
challengeType: 1
|
2020-04-29 10:29:13 +00:00
|
|
|
|
videoUrl: 'https://scrimba.com/c/c4mv4fm'
|
|
|
|
|
forumTopicId: 18277
|
2021-01-13 02:31:00 +00:00
|
|
|
|
dashedName: selecting-from-many-options-with-switch-statements
|
2018-10-10 22:03:03 +00:00
|
|
|
|
---
|
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
# --description--
|
|
|
|
|
|
2021-03-15 03:20:39 +00:00
|
|
|
|
如果你有非常多的选项需要选择,可以使用 <dfn>switch</dfn> 语句。 `switch` 评估一个表达式,将表达式的值与 <dfn>case</dfn> 子句匹配。 从第一个匹配的 `case` 值执行语句,直到遇到 `break`。
|
2020-12-16 07:37:30 +00:00
|
|
|
|
|
2021-03-15 03:20:39 +00:00
|
|
|
|
这是 `switch` 语句的示例:
|
2020-02-17 16:40:55 +00:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
switch(lowercaseLetter) {
|
|
|
|
|
case "a":
|
|
|
|
|
console.log("A");
|
|
|
|
|
break;
|
|
|
|
|
case "b":
|
|
|
|
|
console.log("B");
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2021-03-15 03:20:39 +00:00
|
|
|
|
测试 `case` 值使用严格相等(`===`)运算符进行比较。 `break` 告诉 JavaScript 停止执行 switch 语句。 如果遗漏了 `break` ,下一个语句将会被执行。
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
# --instructions--
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2021-03-15 03:20:39 +00:00
|
|
|
|
写一个测试 `val` 的 switch 语句,并且根据下面的条件来设置不同的 `answer`:
|
|
|
|
|
`1` - `alpha`
|
|
|
|
|
`2` - `beta`
|
|
|
|
|
`3` - `gamma`
|
|
|
|
|
`4` - `delta`
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
# --hints--
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2021-03-15 03:20:39 +00:00
|
|
|
|
`caseInSwitch(1)` 值应该为字符串 `alpha`
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
|
|
|
|
```js
|
2020-12-16 07:37:30 +00:00
|
|
|
|
assert(caseInSwitch(1) === 'alpha');
|
|
|
|
|
```
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2021-03-15 03:20:39 +00:00
|
|
|
|
`caseInSwitch(2)` 值应该为字符串 `beta`
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
```js
|
|
|
|
|
assert(caseInSwitch(2) === 'beta');
|
|
|
|
|
```
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2021-03-15 03:20:39 +00:00
|
|
|
|
`caseInSwitch(3)` 值应该为字符串 `gamma`
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
```js
|
|
|
|
|
assert(caseInSwitch(3) === 'gamma');
|
2018-10-10 22:03:03 +00:00
|
|
|
|
```
|
|
|
|
|
|
2021-03-15 03:20:39 +00:00
|
|
|
|
`caseInSwitch(4)` 值应该为字符串 `delta`
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
```js
|
|
|
|
|
assert(caseInSwitch(4) === 'delta');
|
|
|
|
|
```
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2021-03-15 03:20:39 +00:00
|
|
|
|
不能使用任何 `if` 或 `else` 表达式
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
```js
|
|
|
|
|
assert(!/else/g.test(code) || !/if/g.test(code));
|
|
|
|
|
```
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2021-03-15 03:20:39 +00:00
|
|
|
|
你应该有至少 3 个 `break` 表达式
|
2020-04-29 10:29:13 +00:00
|
|
|
|
|
2018-10-10 22:03:03 +00:00
|
|
|
|
```js
|
2020-12-16 07:37:30 +00:00
|
|
|
|
assert(code.match(/break/g).length > 2);
|
2018-10-10 22:03:03 +00:00
|
|
|
|
```
|
2020-04-29 10:29:13 +00:00
|
|
|
|
|
2021-01-13 02:31:00 +00:00
|
|
|
|
# --seed--
|
|
|
|
|
|
|
|
|
|
## --seed-contents--
|
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
function caseInSwitch(val) {
|
|
|
|
|
var answer = "";
|
|
|
|
|
// Only change code below this line
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Only change code above this line
|
|
|
|
|
return answer;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
caseInSwitch(1);
|
|
|
|
|
```
|
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
# --solutions--
|
|
|
|
|
|
2021-01-13 02:31:00 +00:00
|
|
|
|
```js
|
|
|
|
|
function caseInSwitch(val) {
|
|
|
|
|
var answer = "";
|
|
|
|
|
|
|
|
|
|
switch(val) {
|
|
|
|
|
case 1:
|
|
|
|
|
answer = "alpha";
|
|
|
|
|
break;
|
|
|
|
|
case 2:
|
|
|
|
|
answer = "beta";
|
|
|
|
|
break;
|
|
|
|
|
case 3:
|
|
|
|
|
answer = "gamma";
|
|
|
|
|
break;
|
|
|
|
|
case 4:
|
|
|
|
|
answer = "delta";
|
|
|
|
|
}
|
|
|
|
|
return answer;
|
|
|
|
|
}
|
|
|
|
|
```
|