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 + '个包子呢');
}