JS基础-分支语句

分支语句是流程控制语句当中的一种

可以简单理解为是一种控制条件, 当达到某个条件时,执行相应的代码

IF

IF多条件分支

例如:当 变量 a > b 时, 则执行 语句块1 , 如果 a 等于 b 时,则执行语句块2 ;最后,如果 a > b 时,则执行语句块3

if else 语句当中的语句块一般具有排斥作用。如果执行了语句块1中的内容, 则后续的语句块2至 语句块n 中的内容则不会被执行

用流程图表示如下

用代码表示

<script>
      var a = 10;
      var b = 20;
      if (a > b) {
        // 语句块1
        console.log("a > b = true");
      } else if (a == b) {
        console.log(" a = b = true");
      } else {
        console.log("a < b = true");
      }
    </script>

如果一个 if 语句 只有一行,可以省略大括号,但最好不要这样做, 因为这增加了阅读代码的成本

if (a > b) console.log("a > b = true");

switch

除了if外的另一种流程控制语句, switch适用于当一个变量被分类讨论的情形

例如输入一种水果,返回他们的价格. 这个例子也可以用if实现,只是看起来没那么简洁

水果 价格(元/斤)
西红柿 1.2
香蕉 1.2
苹果 1
西瓜 1
菠萝 1.5
火龙果 1.5

switch的基础语句就如下所示, 注意其中的 break 关键词,如果不写break, 程序即使命中了某个水果,也不会跳出switch语句, 而是继续向下执行,直到碰到 break语句

其中的 default 是用来处理上面都没有命中的情况, 我们给的水果的价格再多, 也不能穷尽所有的水果价格,所以给一个默认值,就显得比较合理

<script>
  var fruit = prompt("请输入水果");
  switch (fruit) {
    case "西红柿":
      alert("西红柿的价格是 1.2");
      break;
    case "香蕉":
      alert("香蕉的价格是1.2");
    case "苹果":
      alert("苹果的价格是1");
      break;
    case "西瓜":
      alert("西瓜的价格是1");
      break;
    case "菠萝":
      alert("菠萝的价格是1.5");
      break;
    case "火龙果":
      alert("火龙果的价格是1.5");
      break;
  }
</script>

以上的代码还可以做简化,我们发现, 西红柿、香蕉价格相同;苹果、西瓜价格相同;菠萝、火龙果价格相同。我们可以做一个分组, 使得代码更加简洁。代码如下

<script>
    var fruit = prompt("请输入水果");
    switch (fruit) {
      case "西红柿":
      case "香蕉":
        alert(`${fruit}的价格是1.2`);
        break;
      case "苹果":
      case "西瓜":
        alert(`${fruit}的价格是1`);
        break;
      case "菠萝":
      case "火龙果":
        alert(`${fruit}的价格是1.5`);
        break;
      default:
        alert("不知道");
        break;
    }
</script>

三目运算符

JavaScript 等高级语言提供了 三目运算符的语法。其本质也是分支条件语句, 相当于单个的 if…else

语法

// condition : 条件表达式,输出 true 或者 false
// 如果 condition 结果为 true 则 返回 expr1 表达式
// 如果 condition 结果为 false 则 返回 expr2 表达式
condition ? expr1 : expr1

例如

理发店会员剪一次30块钱, 非会员剪一次需要288元

<script>
    var member = "非会员";
    var price = member === "会员" ? 30 : 288;
    console.log(price);
</script

微信公众号