关于typescript:TypeScript-条件语句

条件语句用于基于不同的条件来执行不同的动作。判断给出的条件,如果条件为真执行什么代码,如果条件为假又执行什么代码。

TypeScript 中的条件语句其实和 JavaScript 中的条件语句一样,如果曾经相熟 JavaScript 中的条件语句,能够略过此节。

if 条件语句

TypeScriptif 条件语句由一个布尔表达式跟一个代码块组成。

语法格局:

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 都不为真时执行代码块。且 defaultbreak 语句也不是必须的。

示例:

当变量的值为 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 语句,不管怎样都不会出错。

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理