共计 3227 个字符,预计需要花费 9 分钟才能阅读完成。
条件语句用于基于不同的条件来执行不同的动作。判断给出的条件,如果条件为真执行什么代码,如果条件为假又执行什么代码。
TypeScript
中的条件语句其实和 JavaScript
中的条件语句一样,如果曾经相熟 JavaScript
中的条件语句,能够略过此节。
if 条件语句
TypeScript
中 if
条件语句由一个布尔表达式跟一个代码块组成。
语法格局:
if(expression){// 当 expression 为 true 时执行代码块}
示例:
定义一个变量 age
,依据给定的条件表达式,判断用户的年龄是否合乎玩游戏的要求:
var age:number = 22;
// 给定一个条件
if(age >= 18){console.log("已满 18 岁,能够玩游戏");
}
编译成 JavaScript
代码:
var age = 22;
// 给定一个条件
if (age >= 18) {console.log("已满 18 岁,能够玩游戏");
}
输入:
已满 18 岁, 能够玩游戏
if…else 条件语句
在 if
条件语句前面能够接一个可选的 else
语句,当给定的条件为 true
时,执行 if
语句后的代码块,为 false 则执行 else
语句前面的代码块。
语法格局:
if(expression){// 当 expression 为 true 时执行代码块}else{// 当 expression 为 false 时执行}
示例:
下面的示例中咱们给定一个条件,当满足条件时,执行的是 if
语句前面的代码块,而不满足条件则不会执行代码。如果咱们心愿不满足条件时也能执行指定代码,就能够应用 if...else
条件语句。
如下所示当满足条件时,输入“已满 18 岁, 能够玩游戏”,不满足条件时,输入“未成人,不能够玩游戏”:
var age:number = 16;
// 给定一个条件
if(age >= 18){console.log("已满 18 岁,能够玩游戏");
}else{console.log("未成人,不能够玩游戏");
}
编译成 JavaScript 代码:
var age = 16;
// 给定一个条件
if (age >= 18) {console.log("已满 18 岁,能够玩游戏");
}
else {console.log("未成人,不能够玩游戏");
}
输入:
未成人,不能够玩游戏
else if 条件语句
下面讲到的 if...else
条件语句,还有一个缺点,就是当有不同的条件时,不太好进行判断。例如在二年级的考试中,老师给同学们评定等级,分数为 60 以下的等级为 C,60 到 80 的等级为 B,80 以上的等级为 A。这种状况下就咱们能够应用 else if
条件语句。
else if
语句和 if
语句很像,都是前面有一个小括号 ()
而后小括号中为指定的条件表达式,然而两者在应用上有些不必:
- 一个条件语句中个别只有一个
if
语句,而能够由任意数量的else if
语句。 else if
语句个别在if
语句之后,else
语句之前应用。
语法格局:
if(expression1){// 当 expression1 为 true 时执行代码块}else if(expression2){// 当 expression2 为 true 时执行代码块}else{// 当所有表达式都不满足时执行}
示例:
咱们来应用 else if
实现下面提到的等级评定:
var score:number = 88;
if(score < 60){console.log("问题等级为 C");
}else if(score >= 60 && score < 80){console.log("问题等级为 B");
}else{console.log("问题等级为 A");
}
编译成 JavaScript
代码:
var score = 88;
if (score < 60) {console.log("问题等级为 C");
}
else if (score >= 60 && score < 80) {console.log("问题等级为 B");
}
else {console.log("问题等级为 A");
}
输入:
问题等级为 A
switch 语句
switch
语句用于从多个条件执行一个语句,测试一个表达式的值,与 case
的值进行进行匹配,执行匹配胜利的 case
语句前面的代码块。
语法格局:
switch(expression){
case constant-expression :
statement(s);
break;
case constant-expression :
statement(s);
break;
default :
statement(s);
}
一个 switch
语句中能够有任意数量的 case
语句,当 expression
的值与其中一个 constant-expression
匹配时,会执行对应的代码块。
break
语句用于终止 switch
,如果 case
语句中不蕴含 break
,则将会继续执行前面的 case
语句,晓得遇到 break
或者 switch
中的代码执行结束为止。
default
是可选的,用于在下面所有 case
都不为真时执行代码块。且 default
中 break
语句也不是必须的。
示例:
当变量的值为 1 时,输入星期一,为 2 时输入星期二,… 顺次类推:
var week:number = 5;
switch(week) {
case 1:{console.log("星期一");
break;
}
case 2:{console.log("星期二");
break;
}
case 3:{console.log("星期三");
break;
}
case 4:{console.log("星期四");
break;
}
case 5:{console.log("星期五");
break;
}
case 6:{console.log("星期六");
break;
}
case 7:{console.log("星期七");
break;
}
default :{console.log("谬误");
break;
}
}
编译成 JavaScript
代码:
var week = 5;
switch (week) {
case 1: {console.log("星期一");
break;
}
case 2: {console.log("星期二");
break;
}
case 3: {console.log("星期三");
break;
}
case 4: {console.log("星期四");
break;
}
case 5: {console.log("星期五");
break;
}
case 6: {console.log("星期六");
break;
}
case 7: {console.log("星期七");
break;
}
default: {console.log("谬误");
break;
}
}
输入:
星期五
如果咱们在 case
语句中不加 break
,那么执行完满足条件的 case
语句后,会继续执行前面的语句。
咱们来看一下:
var week = 5;
switch (week) {
case 1: {console.log("星期一");
}
case 2: {console.log("星期二");
}
case 3: {console.log("星期三");
}
case 4: {console.log("星期四");
}
case 5: {console.log("星期五");
}
case 6: {console.log("星期六");
}
case 7: {console.log("星期七");
}
default: {console.log("谬误");
}
}
输入:
星期五
星期六
星期七
谬误
总结
在下面这几种条件语句中应该也比较简单。咱们须要留神一下 if...else if...else
语句和 switch
语句都是用于抉择多个代码块之一来执行。那不同状况下如何抉择应用哪种语句呢?
switch
语句通常比一系列嵌套的if
语句效率更高,逻辑更加清晰。倡议在判断固定值的时候应用。if
语句相较于switch
语句更加灵便,任意布尔表达式都能够应用,倡议判断区间或者范畴的时候应用。- 总之,
switch
能做到的,if
都能做到,反之则不行,所以如果你纠结应用哪个语句时,能够抉择if
语句,不管怎样都不会出错。