JavaScript-2.1-JavaScript 流程控制语句-分支结构

分支结构

  • 顺序结构是程序设计的借本结构
    • 按照语句出现的顺序从上到下依次执行
  • 分支结构是需要根据不同条件进行判断,然后执行不同的操作
    • if-else 结构
    • switch-else 结构

一:简单 if 结构

  • 通过判断 if 后面的条件是否成立
    • 如果条件成立,则执行 if 后面的语句
    • 如果条件不成立,则不执行 if 后面的语句
if(判断条件){
	// if条件成立时,代码执行语句块
}

二:if-else 结构

  • 当 if 条件成立时,执行 if 后面的语句
  • 当 if 条件不成立时,执行 else 后面的语句
if(判断条件){
	// 条件为true时执行的代码块
}else{
	// 条件为false时执行的代码块
}

三:多重 if 结构

  • 当第一个 if 成立时判断第二个 if,当第二个 if 不成立时判断第三个 if,依次类推,直到最后一个 else 结构,表示上述所有 if 条件都不成立
if(条件一){
	// 条件一成立
}else if(条件二){
	// 条件一不成立&&条件二成立
	// else-if 部分,可以有N多个
}else{
	// 条件一不成立&&条件二不成立
}

四:嵌套 if 结构

  • 将一个完整的 if 结构包裹在另一个 if 结构里面
  • 嵌套 if 结构是在前一个 if 条件成立时,继续判断下一个 if
if(条件一){
	if(条件二){
		if(条件三){
			// 语句块
		}
	}
}else{
	// 语句块
}
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>嵌套if结构</title>
</head>
<body>
	<script type="text/javascript">
		var num = prompt("Enter a number:");
		if(num>=0){
			if(num>=100){
				document.write(num+">=100");
			}else {
				document.write("0<="+num+"<100");
			}
		}else if(num<0){
			document.write("0<"+num);
		}else{
			document.write("Enter a number,please.");
		}
	</script>
</body>
</html>

效果动态图
在这里插入图片描述

五:switch-case 结构

  • switch-case 语句是专门用于判断多路分支的语句
  • 当存在很多条件的时候,首先考虑使用 switch-case 结构

1、switch-case 的基本语法

  • 先计算 switch 后面表达式的值
  • 然后依次与每个 case 后面的常量表达式进行比对
  • 并执行比对成功的第一个 case 结构
switch(表达式){
	case 常量表达式 1:
		语句 1;
		break;
	case 常量表达式 1:
		语句 1;
		break;
		......
	default:
		语句 N
		break;
}

2、switch-case 的注意事项

  • 在 case 后的各常量表达式的值不能相同,否则只会执行第一个
  • 在 case 后允许有多个语句,可以不用{}括起来
  • 每个 case 语句后需要使用 break 语句来阻止下一个 case 运行
  • 各 case 和 default 子句的先后顺序可以变动,而不会影响程序执行结果
  • defalut 说明了表达式的结果不等于任何一种情况时的操作,可省略
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>switch-case</title>
</head>
<body>
	<script type="text/javascript">
		// 提示用户输入0-3的数字
		var num = parseFloat(prompt("Enter a number(0-3):"));
		switch(num){
			case 0:
				document.write("The number is 0.");
				// break 不可省略
				break;
			case 1:
				document.write("The number is 1.");
				break;
			case 2:
				document.write("The number is 2.");
				break;
			case 3:
				document.write("The number is 3.");
				break;
			default:
				document.write("This is fault.")
		}
	</script>
</body>
</html>

效果动态图
在这里插入图片描述

3、多重 if 结构 与 switch-case 结构的比较

  • 多重 if 结构与 wiitch-case 结构都是用于专门实现多路分支的结构,两者在功能上类似,但是在实际应用的情况下存在一些差异

if 与 switch-case
1.多重 if 结构和 switch-case 结构都可以用来实现多路分支
2.多重 if 结构用来实现两路、三路分支比较方便,而 switch-case 结构实现三路以上分支比较方便
3. switch-case 结构通常用于判断等于的情况,而多种 if 通常用于判断区间范围
4.switch-case 结构的执行效率要比多重 if 结构更快

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值