JavaScript中的分支结构

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript中的分支结构相关的知识,希望对你有一定的参考价值。

说到javascript中的分支结构,我们就不得不提到流程控制这个词,我们所有的程序都是由数据和算法组成的。
程序=数据+算法
通常我们所说的算法都可以通过"顺序","分支","循环"三种结构来组合完成。

技术分享

在ECMA中规定了一些语句(也称为流程控制语句,分支结构语句),从本质上来说,这些语句定义了ECMAScript中的主要语法,语句通常使用一个或者多个关键字来完成给定任务。

1.1 if 语句

if 语句 - 只有当指定条件为 true 时,使用该语句来执行代码

1 if (条件)
2   {
3   只有当条件为 true 时执行的代码
4   }

if...else 语句 - 当条件为 true 时执行代码,当条件为 false 时执行其他代码

技术分享
1 if (条件)
2   {
3   当条件为 true 时执行的代码
4   }
5 else
6   {
7   当条件不为 true 时执行的代码
8   }
技术分享

if...else if....else 语句 - 使用该语句来选择多个代码块之一来执行

技术分享
 1 if (条件 1)
 2 {
 3 当条件 1 为 true 时执行的代码
 4 }
 5 else if (条件 2)
 6 {
 7 当条件 2 为 true 时执行的代码
 8 }
 9 else
10 {
11 当条件 1 和 条件 2 都不为 true 时执行的代码
12 }
技术分享

 

1.2 switch 语句

使用 switch 语句来选择要执行的多个代码块之一。

技术分享
 1 switch(n)
 2 {
 3 case 1:
 4   执行代码块 1
 5   break;
 6 case 2:
 7   执行代码块 2
 8   break;
 9 default:
10   n 与 case 1 和 case 2 不同时执行的代码
11 }
技术分享

工作原理:首先设置表达式 n(通常是一个变量)。随后表达式的值会与结构中的每个 case 的值做比较。如果存在匹配,则与该 case 关联的代码块会被执行。请使用 break 来阻止代码自动地向下一个 case 运行。

default 关键词
请使用 default 关键词来规定匹配不存在时做的事情:

技术分享
 1 var day=new Date().getDay();
 2 switch (day)
 3 {
 4 case 6:
 5   x="Today it‘s Saturday";
 6   break;
 7 case 0:
 8   x="Today it‘s Sunday";
 9   break;
10 default:
11   x="Looking forward to the Weekend";
12 }
技术分享

解释:今天不是周六或者周日才会执行的代码段。

1.3 if 与 switch 的比较

技术分享
switch case vs else if
     switch case 仅用于等于比较的条件
     else if 可用任意条件
     
     if(Boolean(条件)) else if()
       自带隐式转换,将条件转为boolean
       效率稍微低
     switch case 
       不带隐式转换的等于比较,效率稍微高
技术分享

 

以上是关于JavaScript中的分支结构的主要内容,如果未能解决你的问题,请参考以下文章

原生JavaScript第二篇

你可能不知道的JavaScript代码片段和技巧(下)

你可能不知道的JavaScript代码片段和技巧(上)

从无到有JavaScript新手教程——2.分支结构和循环

GitGit 分支管理 ( 克隆远程分支 | 克隆 master 分支 git clone | 查看远程分支 git branch -a | 克隆远程分支 git checkout -b )(代码片段

GitGit 分支管理 ( 克隆远程分支 | 克隆 master 分支 git clone | 查看远程分支 git branch -a | 克隆远程分支 git checkout -b )(代码片段