美文网首页
TypeScript 条件语句

TypeScript 条件语句

作者: 暖A暖 | 来源:发表于2021-03-15 10:42 被阅读0次

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

    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 语句,不管怎样都不会出错。

    相关文章

      网友评论

          本文标题:TypeScript 条件语句

          本文链接:https://www.haomeiwen.com/subject/kjtkcltx.html