JavaScript流程控制(JS语句)

在一个程序执行的过程中,各条代码的执行顺序对程序的结果是有直接影响的。很多时候我们要通过控制代码的执行顺序来实现我们要完成的功能。
简单理解:流程控制就是来控制我们的代码按照什么结构顺序来执行
流程控制主要有三种结构,分别是顺序结构、分支结构、循环结构,这是三中结构代表三种代码执行的顺序

(一)、顺序流程控制

顺序结构是程序中最简单的、最基本的流程控制,它没有特定的语法结构,程序会按照代码的先后顺序,依次执行,程序中大多数的代码都是这样执行的.
代码块:
程序是由一条条语句构成的,按照从上到下的顺序一条条执行的,在js中,可以使用{}来为语句进行分组, 同一个{}中的语句,我们称为一组语句,它们要么都执行,要么都不执行,一个{}中的语句,我们也称为一个代码块
在代码块的后边,就不用编写;号了, js中的代码块,只具有分组的作用,没有其他的用途,代码块内容的内容,在外部是完全可见的

(二)、分支流程控制

由上到下执行代码的过程中,根据不同的条件,执行不同的路径代码(执行代码多选一的过程),从而得到不同的结果

1、if分支语句

条件判断语句
-使用条件判断语句可以在执行某个语句之前进行判断,如果条件成立才会执行语句,条件不成立,则语句不执行

(1)、 if语句

语法结构:
if (条件表达式) { 执行语句.... };
执行思路:
if语句在执行时,会先对条件表达式进行求值判断,如果条件表达式的值为true,则执行if后的语句; 如果条件表达式的值为false,则不会执行if后的语句;
注意:
if语句只能控制紧随其后的那个语句,如果希望if语句可以控制多条语句,可以将这些语句统一放在代码块中。
如果就一条if语句,代码块不是必须的,但在开发中尽量写清楚
代码验证:弹出一个输入框,要求用户输入年龄,如果年龄大于等于18岁,允许进网吧

<script>
  if (true) console.log("好好学习,天天向上");
  //  加上条件运算符  &&  ||
  var a = 20;
  if (a > 10 && a <= 20) {
    console.log("a在10-20之间");
    console.log("4567");
  }
  //  弹出一个输入框,要求用户输入年龄,如果年龄大于等于18岁,允许进网吧
  var age = prompt("请输入年龄");
  if (age >= 18) {
    alert("欢迎光临");
  }
</script>
(2)、 if....else...语句

语法结构
if(条件表达式){
        执行语句1....
} else {
        执行语句2....
}
执行思路
当该语句执行时,会先对if后的条件进行判断,如果该值为true,则执行if后的语句,如果该值为false,则执行else后的语句,两者选其一执行

代码验证:弹出一个输入框,要求用户输入年龄,如果年龄大于等于18岁,允许进网吧,否则,让回家好好学习

<script>
  var age = prompt("请输入年龄");
  if (age >= 18) {
    alert("你已经" + age + "岁,欢迎光临");
  } else {
    alert("你才" + age + "岁,回家学习吧");
  }
</script>
(3)、if...else if...else语句(多分支语句)

语法结构:
if (条件表达式) {
        执行语句....
} else if (条件表达式) {
        执行语句....
} else {
        上述都不成立,执行语句
}

执行思路:
当该语句执行时,会从上到下依次对条件表达式进行求值,如果值为true,则执行当前语句;如果值为false,则继续向下判断; 如果所有的条件都不满意,就执行最后一个else或者不执行,该语句中,只会有一个代码块被执行,一旦代码块执行了, 则直接结束语句 ;else if 理论上是可以有多个的

<script>
      var age = prompt("请输入年龄");
      if (age < 18) {
        alert("你还未成年");
      } else if (age >= 18 && age <= 60) {
        alert("你需要努力工作,养家活口");
      } else {
        alert("你可以颐养天年了");
      }
    </script>

案例:

根据用户输入的分数,有不同的奖励:

        1:  90分以上,奖励宝马
        2:  80-90分,奖励100元
        3:  70-80分,奖励书包
        4:  60-70分,奖励练习册
        5:  60分以下,奖励棍棒炒肉丝

<script>
    var scores = +prompt('用户输入的分数0-100');
    if (scores > 90 && scores <= 100) {
      alert('奖励宝马')
    } else if (scores > 80 && scores <= 90) {
      alert('奖励100元')
    } else if (scores > 70 && scores <= 80) {
      alert('奖励书包')
    } else if (scores >= 60 && scores <= 70) {
      alert('奖励练习册')
    } else {
      alert('奖励棍棒炒肉丝')
    }
</script>

2、三元表达式

有三元运算符组成的式子,我们成为三元表达式
语法结构:条件表达式 ?表达式1 : 表达式2
执行思路:如果条件表达式为真,返回表达式1的值,如果条件表达式为假,返回表达式2的值
代码验证:
如果年龄达到了18岁,则显示成年了,否则返回未成年

<script>
  var age3 = prompt("请输入年龄");
  age3 >= 18 ? alert("欢迎光临") : alert("回家学习吧");
</script>

案例:用户输入数字,如果数字小于10,则在前面补0,比如01,如果数字大于10,则不需要补,如20

<script>
  var num = prompt("请输入数字");
  // if实现
  // if (num > 0 && num < 10) {
  //   num = "0" + num;
  // }
  // 三元表达式实现
  num = num > 0 && num < 10 ? "0" + num : num;
  alert(num);
</script>

3、switch分支语句( switch...case...语句)

switch语句也是多分支语句,它用于基于不同条件来执行不同的代码,当要针对变量设置一系列的特定值的选项时,就可以用switch语句;
switch转换,开关的意思;case 选项的意思; break退出语句
语法结构:
switch(条件表达式){
        case 表达式:
                执行语句....;
                break;
        case 表达式:
                执行语句....
                break;
        ······
        default:
                执行语句...;
}
执行流程:
在执行时,会依次将case后的表达式的值和switch后的条件表达式的值,进行全等比较,如果比较结果为true,则从当前case处开始执行代码,当前case后的所有代码都会执行,我们可以在case的后边跟着一个break关键字,这样可以确保只会执行当前case后的语句,而不会执行其他的case, 如果比较结果为false,则继续向下比较匹配,如果所有的比较结果都为false,则只执行default后的语句
区别:
switch语句和if语句的功能实际上有重复的,使用switch可以实现if的功能,一般情况下,两者是可以互相替换的
switch···case语句通常处理case为比较确定值得情况下,而if···else···语句更加灵活,常用于范围判断
switch语句进行条件判断后直接执行到程序的条件语句,效率更高,而if···else语句有几种条件,有几种条件就得判断多少次
当分支比较少的时,if···else语句的执行效率比switch语句

<script>
      var num = 2;
      switch (num) {
        case 1:
          console.log("壹");
          //使用break可以退出switch语句
          break;
        case 2:
          console.log("贰");
          break;
        case 3:
          console.log("叁");
          break;

        default:
          console.log("非法数字~~~");
          break;
      }
    </script>

案例:
        用户输入水果,跟case里的值进行匹配,弹出对应的信息,如果没有对应的信息,弹出没有此水果。

<script>
    var fruit = prompt('请输入水果名称:');
    switch(fruit){
      case '香蕉':
        alert('香蕉');
        //终止跳出它现在执行的内容
        break;
      case '苹果':
        alert('苹果');
        //终止跳出它现在执行的内容
        break;
      case '车厘子':
        alert('车厘子');
        //终止跳出它现在执行的内容
        break;
      default:
        alert('没有此水果');
        break;
     }
</script>

(三)、循环语句

在实际问题中,有很多具有规律性的重复操作,因此在程序中要完成这类操作就需要重复执行某些语句

1、for循环

在程序中,一组被重复执行的语句被成为循环体,能否继续重复执行,取决于循环的终止条件,由循环体及循环终止条件组成的语句,我们称之为循环语句
for循环,重复执行某些代码,通常跟计数有关系
语法结构:
在for循环中,为我们提供了专门的位置,用来放三个表达式
1:初始化表达式:用var声明的一个普通的变量,通常用于作为计数器使用
2:条件表达式 :用来决定每一次循环是否继续执行,就是终止的条件
3:更新表达式(操作表达式):每次循环,最后执行的代码,经常用于我们计数器变量进行更新
for(初始化表达式;条件表达式;更新表达式){
        循环体....
}

<script>
  //第一种写法
  for(var i=0;i<10;i++){
    alert(i);
  }

  //第二种写法  for循环中的三个部分都可以省略,也都可以写在外部
  var i=0;
  for(;i<10;){
    alert(i++);
  }

  //如果在for循环中,不写任何的表达式,只写两个;
  //此时循环是一个死循环,会一直执行下去,慎用
  for(;;){
    alert("hello");
  }
</script>

for循环的执行流程:
1:初始化表达式,初始化变量(初始化表达式,只会执行一次)
2:条件表达式,判断是否执行循环体,
3:如果为true,则执行循环,如果为false,终止循环
4:执行更新表达式,更新表达式执行完毕继续重复2
断点调试:
断点调试是指自己在程序的某一行设置一个断点,调试时,程序运行到这一行就会停住,然后你可以一步一步往下调试,调试的过程中可以看到各个变量当前的值,出错的话,调试到出错的代码行既显示错误,停下。
扩展:
1、for循环,循环可以执行重复的代码
2、for循环,循环也可以执行不同的代码,因为由计数器变量i的存在,i每次循环值都会变化
3、for循环,因为由计数器的存在,还可以重复执行某些操作,比如做一些算数运算:例如:求1-100之间的累加和
案例:
1、要求用户输入班级人数,之后依次输入每个学生的成绩,最后打印出该班级总的成绩以及平均成绩

<script>
  var num = +prompt("请输入班级人数:");
  var sum = 0;
  var ave = 0;
  for (var i = 1; i <= num; i++) {
    var soce = +prompt("第" + i + "个同学的成绩是:");
    sum += soce;
  }
  ave = sum / num;
  console.log("总分:" + sum);
  console.log("均分:" + ave);
</script>

2、打印一行五个小星星 *****

<script>
    for(var i = 0; j < 5; j++){
      document.write("*")
    }
</script>

3、求1-100之间所有偶数和奇数的和

<script>
    var odd = 0;
    var even = 0;
    for(var i = 1; i<= 100; i++){
      if(i % 2 == 0){
        even += i
      } else {
        odd += i
      }
    }
    console.log('even:', even);
    console.log('odd:', odd);
</script>

4、求1-100之间所有数的平均值

<script>
    var sum=0;
    var average=0;
    for(var i = 1; i <= 100; i++){
      sum += i
    }
    average= sum / 100
    console.log(average)
</script>

双重for循环:
循环嵌套是指在一个循环语句中再定义一个循环语句的语法结构,例如再for循环语句中,可以再嵌套一个for循环,这样的for循环语句,我们称之为双重for循环。
语法结构:
for(外层的初始表达式;外层的条件表达式;外层的操作表达式){
        for(里层的初始表达式;里层的条件表达式;里层的操作表达式){
                执行语句
        }
}
执行思路:
1、可以把里面的循环看作是外层循环的语句
2、外层循环循环一次,里面的循环执行全部
案例:

1、第一个图形

2、第二个图形

3、第三个图形

4、九九乘法表

*****
*****
*****
*****
*****

*
**
***
****
*****

*****
****
***
**
*

   

<script>
 // 第一种图形 写法一
  for (var i = 0; i < 5; i++) {
    for (var j = 0; j < 5; j++) {
      document.write("* &nbsp;&nbsp;&nbsp;");
    }
    document.write("<br/>"); //循环完一次 输出一个换行
  }
  // 写法二
  // *       1  <1  i=0
  // **      2  <2  i=1
  // ***     3  <3  i=2
  // ****    4  <4  i=3
  // *****   5  <5  i=4
  var str = "";
  for (var i = 0; i < 5; i++) {
    for (var j = 0; j < 5; j++) {
      str += "*";
    }
    // 一行打印完5个星星后,就要另起一行
    str = str + "<br/>";
  }
  document.write(str);

  //第二种图形
  for (var i = 0; i < 5; i++) {
    for (var j = 0; j < i + 1; j++) {
      document.write("* &nbsp;&nbsp;&nbsp;");
    }
    document.write("<br/>"); //输出一个换行
  }

  //第三种图形
  // *****   1  j<5(5-0)  i=0
  // ****    2  j<4(5-1)  i=1
  // ***     3  j<3(5-2)  i=2
  // **      4  j<2(5-3)  i=3
  // *       5  j<1(5-4)  i=4

  for (var i = 0; i < 5; i++) {
    for (var j = 0; j < 5 - i; j++) {
      document.write("* &nbsp;&nbsp;&nbsp;");
    }
    document.write("<br/>"); //输出一个换行
  }
  // 9 *9 乘法表
  for (var i = 1; i <= 9; i++) { // 获得1-9之间的数字 ,获得打印的行数,高度
    for (var j = 1; j <= i; j++) { // 获得i以内的所有数字,获取每行打印的次数
      document.write(`${j} x ${i} = ${j * i} &nbsp;&nbsp;`)
    }
    document.write('<br>')
  }
</script>

2、while循环

while语句可以在条件表达式为真的前提下,循环执行指定的一段代码,直到表达式不为真时,结束循环。
while语句的语法结构
while(条件表达式){
        循环体代码
}
执行思路:
(1)、先执行条件表达式,如果结果为true,则执行循环体代码;如果为false,则退出循环,执行后面的代码
(2)、执行循环体代码
(3)、循环体代码执行完毕后,程序会继续判断执行条件表达式,如条件仍为true,则会继续执行循环体,直到循环条件为false时,整个循环过程才会结束
注意:
1、while循环里面也有计数器,初始化变量
2、while循环里应该也有操作表达式,完成计数器的更新,防止死循环

<script>
  var i=0;//1:创建初始化一个变量
  while(i<5){// 2:在循环中设置一个条件表达式
    alert(i);
    i++;  // 3:定义一个更新表达式,每次更新初始化变量
  }
</script>

案例:
计算1-100之间所有整数的和

<script>
  var i = 1,
    sum = 0;
  while (i < 100) {
    sum += i;
    i++;
  }
  console.log(sum);
</script>

3、do···while循环

do···while语句其实是while语句的一个变体,该循环会先执行一次代码块,然后对条件表示式进行判断,如果条件为真,就会重复执行循环体,否则退出循环
语法结构
do{
        循环体
}while(条件表达式)
执行思路:
先执行一次循环体,再判断条件,如果条件表达式结果为真,则继续执行循环体,否则退出循环;
do...while可以保证循环体至少执行一次,而while不行

4、continue、break关键字

(1)、continue关键字

可以用来跳过当次循环,同样continue也是默认只会对离他最近的循环起作用

<script>
  for (var i = 0; i < 5; i++) {
    if (i == 2) {
      continue;
    }
    console.log(i);
  }
</script>

(2)、 break关键字
可以用来退出循环语句;会立即终止离他最近的那个循环语句

<script>
  for (var i = 0; i < 5; i++) {
    console.log(i);
    //break;//用来结束for的循环语句,for只会循环一次
    if (i == 2) {
      break; //这个break是对整个for循环起作用的
    }
  }


  for (var i = 0; i < 5; i++) {
    console.log("@外层循环" + i);
    for (var j = 0; j < 5; j++) {
      break; //只会结束离他最近的内层循环
      console.log("内层循环" + j);
    }
  }
</script>

(3)、break指定结束循环体
可以为循环语句创建一个标签名,来标识当前的循环;
语法:
标签名:循环语句
使用break语句时,break 标签名,可结束指定的循环,而不是最近的

<script>
  outer: for (var i = 0; i < 5; i++) {
    console.log("@外层循环" + i);
    for (var j = 0; j < 5; j++) {
      break outer; //指定结束外层的for循环
      console.log("内层循环" + j);
    }
  }
</script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值