6、流程控制

6、流程控制

1. 流程控制概念

​ 流程控制就是来控制代码按照一定结构顺序来执行

​ 流程控制主要有三种结构:顺序结构、分支结构、循环结构

2. 顺序流程控制

3. 分支流程控制

​ JS 语言提供了两种分支结构语句:if 语句、switch 语句

3.2 if 语句

  • 语法结构
// 条件成立执行代码,否则什么也不做
if (条件表达式) {
    // 条件成立执行的代码语句
}
  • 执行流程

// 弹出一个输入框,要求用户输入年龄,如果年龄大于等于 18 岁,允许进网吧
var age = prompt('请输入年龄');
        if (age >= 18) {
            alert('come on')
        }
3.2.1 if else双分支语句
  • 语法结构

    // 条件成立  执行 if 里面代码,否则执行else 里面的代码
    // 二选一
    if (条件表达式) {
        // [如果] 条件成立执行的代码
    } else {
        // [否则] 执行的代码
    }
    
    
  • 执行流程

// 接收用户输入的年份,如果是闰年就弹出闰年,否则弹出是平年
var year = prompt('请输入年份');
        if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0) {
            // 能被4整除且不能整除100的为闰年(如2004年就是闰年,1901年不是闰年)或者能够被400整除的就是闰年
            alert('闰年')
        } else {
            alert('平年');
        }
3.2.2 if else if 多分支语句
  • 语法结构

    // 适合于检查多重条件
    // 多选一
    if (条件表达式1) {
        语句1} else if (条件表达式2)  {
        语句2} else if (条件表达式3)  {
       语句3....
    } else {
        // 上述条件都不成立执行此处代码
    }
    
    
  • 执行逻辑

// 接收用户输入的分数,根据分数输出对应的等级字母 A、B、C、D、E
// 注意要按照从大到小判断的思路写
  var score = prompt('请输入分数');
        if (score >= 90) {
            alert('A');
        } else if (score >= 80) {
            alert('B');
        } else if (score >= 70) {
            alert('C');
        } else {
            alert('D');
        } 
3.2.3三元表达式

类似于简化版的 if else

  • 语法结构

    表达式1 ? 表达式2 : 表达式3;
    
  • 执行思路

    • 如果表达式1为 true ,则返回表达式2的值,如果表达式1为 false,则返回表达式3的值
    • 简单理解: 就类似于 if else (双分支) 的简写
// 用户输入数字,如果数字小于10,则在前面补 0 ,比如01,09 ,如果数字大于10,则不需要补,比如 20 
var time = prompt('请输入一个0~59的数字');
        var time2 = time < 10 ? '0' + time : time;
        alert(time2);

3.3switch分支流程控制

针对变量设置一系列的特定值的选项

  • 语法结构

    switch( 表达式 ){ 
        case value1:
            // 表达式 等于 value1 时要执行的代码
            break;
        case value2:
            // 表达式 等于 value2 时要执行的代码
            break;
        default:
            // 表达式 不等于任何一个 value 时要执行的代码
    }
    
  • 执行思路

    (1)关键字 switch 后面括号内可以是表达式或值。变量

    (2)关键字 case , 后跟一个选项的表达式或值

    (3)执行case 里面的语句时,如果没有break,则继续执行下一个case里面的语句

    (4)switch 表达式的值会与结构中的 case 的值做比较

    • 如果存在匹配全等(===) ,则与该 case 关联的代码块会被执行,并在遇到 break 时停止,整个 switch 语句代码执行结束

    • 如果所有的 case 的值都和表达式的值不匹配,则执行 default 里的代码

// 用户在弹出框里面输入一个水果,如果有就弹出该水果的价格, 如果没有该水果就弹出“没有此水果”
var fruit = prompt('请输入您想要的水果:');
        switch (fruit) {
            case '苹果':
                alert('22.5元/斤');
                break;
            case '香蕉':
                alert('32.5元/斤');
                break;
            default:
                alert('没有此水果');
                break;
        }

3.4 switch 语句和 if else if 语句的区别

  • switch多用于特定的变量值,if else if多用于有范围的变量
  • switch多用于分支多的,直接跳转执行快,if else if多用于分支少的,一句一句执行慢

4.循环流程控制

循环的目的:重复执行某些代码(循环语句=循环体+终止条件)

4.1 for循环

​ for循环:把某些代码重复若干次,通常和计数有关

  • 语法结构
for(初始化变量; 条件表达式; 操作表达式 ){
    //循环体
}
名称作用
初始化变量用var 声明的一个普通变量,通常用于作为计数器使用
条件表达式用来决定每一次循环是否继续执行,是终止的条件
操作表达式每次循环最后执行的代码,经常用于对计数器变量进行更新(递增或者递减)
  • 执行顺序

    • (第一轮)

      初始化变量——条件表达式(满足)——循环体——操作表达式

    • (第二轮)

      条件表达式(满足)——循环体——操作表达式

    • 若不满足就退出循环

  • 循环相同的代码

// 输出10句“我错了” 
// 基本写法
for(var i = 1; i <= 10; i++){
    console.log('我错了~');
}
// 用户控制循环次数
var num = prompt('请输入次数:')for ( var i = 1 ; i <= num; i++) {
    console.log('我错了~');
} 
  • 循环不相同的代码

​ for循环可以循环不同的代码, 计数器i的存在可以使循环值变化

// 求输出1到100岁 
for (var i = 1; i <= 100; i++) {
      console.log('这个人今年' + i + '岁了');
}
// 求输出1到100岁,并提示出生、死亡
// for 里面是可以添加其他语句的 
for (var i = 1; i <= 100; i++) {
 if (i == 1) {
    console.log('这个人今年1岁了, 它出生了');
 } else if (i == 100) {
    console.log('这个人今年100岁了,它死了');
  } else {
       console.log('这个人今年' + i + '岁了');
  }
}
  • 循环某些相同的操作
// for循环可以循环某些相同的操作
// 1.求1-100之间所有整数的累加和
        var sum = 0;
        for (var i = 1; i <= 100; i++) {
            sum += i;
        }
        console.log(sum);
// 2. 求1-100之间所有数的平均值
        var sum = 0;
        var average = 0;
        for (var i = 1; i <= 100; i++) {
            sum += i;
        }
        average = sum / 100;
        console.log(average);
 // 3. 求1-100之间所有偶数和奇数的和
        var sum1 = 0;
        var sum2 = 0;
        for (var i = 1; i <= 100; i++) {
            if (i % 2 == 0) {
                sum1 += i;
            } else {
                sum2 += i;
            }
        }
        console.log(sum1);
        console.log(sum2);
 // 4. 求1-100之间所有能被3整除的数字的和
        var sum3 = 0;
        for (var i = 1; i <= 100; i++) {
            if (i % 3 == 0) {
                sum3 += i;
            }
        }
        console.log(sum3);
// 5.用户输入班级人数,之后依次输入每个学生的成绩,最后打印出该班级总的成绩以及平均成绩
        var num = prompt('请输入班级人数');
        var sum4 = 0;
        for (var i = 1; i <= num; i++) {
            var score = prompt('请输入第' + i + '个学生成绩');
            sum4 = sum4 + parseFloat(score);
            // 注意这里prompt输出的是字符串无法参与计算
        }
        alert(sum4);
        var average = sum4 / num;
        alert(average);
// 6.一行打印5个心心:追加字符串
        var str = '';
        for (var i = 1; i <= 5; i++) {
            str = '♥' + str
        }
        console.log(str);

4.2 双重for循环

  • 双重 for 循环概述

    (1)循环嵌套是指在一个循环语句中再定义一个循环语句的语法结构

    (2)里层循环可以看作外层循环的语句

    (3)外层循环每执行一次,里层循环全部执行一次

  • 双重 for 循环语法

    for (外循环的初始; 外循环的条件; 外循环的操作表达式) {
        for (内循环的初始; 内循环的条件; 内循环的操作表达式) {  
           需执行的代码;
       }
    }
    
    for (var i = 1; i <= 3; i++) {
         console.log('这是外层循环第' + i + '次');
         for (var j = 1; j <= 3; j++) {
         console.log('这是里层的循环第' + j + '次');
         // 相当于外层一共循环了3次,里层一共循环了9次
                }
            }
    
  • 循环案例

    // 1.打印n行n列的星星
      var rows = prompt('请您输入行数:');
      var cols = prompt('请您输入列数:');
      var str2 = '';
      for (var i = 1; i <= rows; i++) { //外层循环负责打印行
      for (var j = 1; j <= cols; j++) { //里层循环负责打印列
                    str2 = str2 + '♥';
                }
                str2 += '\n';
            }
            console.log(str2);
    // 2.打印倒三角形
            var rows = prompt('请您输入行数:');
            var cols = prompt('请您输入列数:');
            var str2 = '';
            for (var i = 1; i <= rows; i++) {
                for (var j = i; j <= cols; j++) {
                    str2 = str2 + '♥';
                }
                str2 += '\n';
            }
            console.log(str2);
    // 3.打印九九成法表
            var str6 = '';
            for (var i = 1; i <= 9; i++) {
                for (var j = 1; j <= i; j++) {
                str6 += j + 'x' + i + '=' + j * i + '\t';
                    // \t比\b缩进的更多
                }
                str6 += '\n';
            }
            console.log(str6);
    

4.3 while循环

while语句的语法结构如下:

while (条件表达式) {
    // 循环体代码 
}

执行思路:

  • 先执行条件表达式,如果结果为 true,则执行循环体代码;如果为 false,则退出循环,执行后面代码

  • 循环体代码执行完毕后,程序会继续判断执行条件表达式,如条件仍为true,则会继续执行循环体,直到循环条件为 false 时,整个循环过程才会结束

  • 使用 while 循环时一定要注意,它必须要有退出条件,否则会成为死循环

 // 1.打印人从1-100岁
        var num = 1;
        while (num <= 100) {
            console.log('他今年' + num + '岁了');
            num++;
        }
// 2.计算1-100之间所有整数的和
        var sum4 = 0;
        var num2 = 1;
        while (num2 <= 100) {
            sum4 += num2;
            num2++;
        }
        console.log('1-100之间所有整数的和是' + sum4);
// 3. 弹出一个提示框, 你爱我吗?  如果输入我爱你,就提示结束,否则,一直询问。
        var message = prompt('你爱我吗');
        while (message !== '我爱你') {
            message = prompt('你爱我吗');
        }

4.4 do-while循环

while 和 do while 相比 for 更灵活,但 for 用的更多

do… while 语句的语法结构如下:

do {
    // 循环体代码 - 条件表达式为 true 时重复执行循环体代码
} while(条件表达式);

执行思路

  • 先执行一次循环体代码
  • 再执行条件表达式,如果结果为 true,则继续执行循环体代码,如果为 false,则退出循环,继续执行后面代码
  • 先再执行循环体,再判断,do…while循环语句至少会执行一次循环体代码
  • do while和do循环最大的区别就是 循环体 的执行顺序不同
 // 1.打印人从1-100岁
        var i = 1;
        do {
            console.log('他今年' + num + '岁了');
            i++;
        } while (i <= 100)
 // 2.计算 1 ~ 100 之间所有整数的和
        var sum5 = 0;
        var j = 1;
        do {
            sum += i;
            j++;
        } while (j <= 100)
        console.log('1-100之间所有整数的和是' + sum5);
  // 3.弹出一个提示框, 你爱我吗?  如果输入我爱你,就提示结束,否则,一直询问
        do {
            var mass = prompt('你爱我吗');
        } while (mass !== '我爱你')

4.5 continue、break 关键字

4.5.1 continue

continue 关键字用于立即跳出本次循环,继续下一次循环(本次循环体中 continue 之后的代码就会少执行一次)。

例如,吃5个包子,第3个有虫子,就扔掉第3个,继续吃第4个第5个包子,其代码实现如下:

 for (var i = 1; i <= 5; i++) {
     if (i == 3) {
         console.log('这个包子有虫子,扔掉');
         continue; // 跳出本次循环,跳出的是第3次循环 
      }
      console.log('我正在吃第' + i + '个包子呢');
 }

运行结果:

4.5.2 break

break 关键字用于立即跳出整个循环(循环结束)。

例如,吃5个包子,吃到第3个发现里面有半个虫子,其余的不吃了,其代码实现如下:

for (var i = 1; i <= 5; i++) {
 if (i == 3) {
     break; // 直接退出整个for 循环,跳到整个for下面的语句
 }
 console.log('我正在吃第' + i + '个包子呢');
}

运行结果:

5.断点调试

​ 断点调试可以帮助观察程序的运行过程,在程序的某一行设置一个断点,调试时,程序运行到这一行就会停住,然后手动一步一步往下调试,调试过程中可以看各个变量当前的值,调试到出错的代码行即显示错误停下。

断点调试的流程:
1、浏览器中按 F12--> sources -->找到需要调试的文件-->在程序的某一行设置断点
2、Watch: 监视,通过watch可以监视变量的值的变化,非常的常用。
3、摁下F11,程序单步执行,让程序一行一行的执行,这个时候,观察watch中变量的值的变化。

其余的不吃了,其代码实现如下:

for (var i = 1; i <= 5; i++) {
 if (i == 3) {
     break; // 直接退出整个for 循环,跳到整个for下面的语句
 }
 console.log('我正在吃第' + i + '个包子呢');
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值