4.1 if条件语句

本节介绍ECMAScript语法中最基本的if条件语句,if条件语句是使用频率最高的流程控制语句。对于if条件语句的语法形式有很多种,尤其是与else关键字配合起来使用,表现形式更为多样。

4.1.1 if语句

ECMAScript语法规范中定义的if语句是最基本的条件选择语句,相当于“如果…则…”的条件选择。

if条件语句的语法格式如下:

   if(条件) {
   仅当条件为 true 时,执行此处代码
   }

下面来看一个使用if语句的代码示例(详见源代码ch04目录中ch0-js-if.html文件)。

【代码4-1】

   01  <script type="text/javascript">
   02       if(true) {
   03           console.log("if(true) {");
   04           console.log("    true");
   05           console.log("}");
   06       }
   07       if(false)
   08           console.log("if(false) {");
   09           console.log("    false");
   10           console.log("}");
   11  </script>

关于【代码4-1】的分析如下:

第02~06行代码是第一个if语句块,主要是通过if语句判断“true”是否为真,如果为“真”则执行第03~05行代码控制输出调试信息;

第07~10行代码是意图模仿第02~06行代码的第二个if语句块,主要是通过if语句判断“false”是否为真,如果不为“真”则不执行第08~10行代码。读者可能注意到第07~10行代码中语句块没有“{}”符号,那么这个模仿的第二个if语句块会不会和第一个if语句块功能完全一样呢?

运行测试【代码4-1】所定义的HTML页面,并使用调试器查看控制台输出的调试信息,页面效果如图4.1所示。

图4.1 if语句

从图4.1可知,第02~06行代码的第一个if语句块输出的内容是符合预期的;而第07~10行代码的第二个if语句块输出的内容比较奇怪,原本由于if语句判断条件为布尔值(“fasle”)后不会得到任何输出,但第09~10行代码的内容却输出了,而第08行代码的内容却没有输出。这是由于第二个if语句块没有“{}”符号的缘故造成的,其默认只将第08行代码当作if语句块的语句体,而第09~10行代码不是其语句体,因此这两行代码的内容也就得到输出。

4.1.2 if…else…语句

ECMAScript语法规范中定义的“if…else…”语句是对if语句的增强,相当于“如果…则…,否则…”条件选择。

if…else…语句的语法格式如下:

   if (条件) {
   仅当条件为 true 时,执行此处代码
   } else {
   否则执行此处代码
   }

下面来看一个使用if…else…语句的代码示例(详见源代码ch04目录中ch04-js-if-else.html文件)。

【代码4-2】

   01  <script type="text/javascript">
   02       if(true) {
   03           console.log("if(true) {");
   04           console.log("    true");
   05           console.log("}");
   06       } else {
   07           console.log("else {");
   08           console.log("    false");
   09           console.log("}");
   10       }
   11       if(false) {
   12           console.log("if(true) {");
   13           console.log("    true");
   14           console.log("}");
   15       } else {
   16           console.log("else {");
   17           console.log("    false");
   18           console.log("}");
   19       }
   20  </script>

关于【代码4-2】的分析如下:

第02~10行代码是第一个if…else…语句块,主要是通过if语句判断“true”是否为真,如果为“真”则执行if语句块中的第03~05行的代码并在控制台中输出调试信息,否则执行else语句块内的第07~09行的代码并在控制台中输出调试信息;

第11~19行代码是第二个if…else…语句块,主要是通过if语句判断“false”是否为真,然后相应地执行if和else语句块内的代码。

页面效果如图4.2所示。对于if…else…条件选择语句,运行中只能执行if语句块或else语句块中的内容,二者不可能都执行,不过也不可能都不执行,这也正是if…else…条件选择语句的特点。

图4.2 if…else…语句

4.1.3 if…else if…else…语句

ECMAScript语法规范中定义的if…else if…else…语句是条件选择语句的最完整版本,相当于“如果…则…,如果…则…,否则…”条件选择,基本可以适用于编程中遇到的任何情况。

if…else if…else…语句的语法格式如下:

   if (条件1) {
   仅当条件1为 true 时,执行此处代码
   } else if (条件2) {
   仅当条件2为 true 时,执行此处代码
   } … {
   …
   } else if (条件n) {
   仅当条件n为 true 时,执行此处代码
   } else {
   否则执行此处代码
   }

下面来看一个使用if…else if…else…语句的代码示例(详见源代码ch04目录中ch04-js-if-else-if.html文件)。

【代码4-3】

   01  <script type="text/javascript">
   02       if(true) {
   03           console.log("1- if");
   04       } else if (false) {
   05           console.log("1- else if");
   06       } else {
   07           console.log("1- else");
   08       }
   09       if(false) {
   10           console.log("2 - if");
   11       } else if (true) {
   12           console.log("2 - else if");
   13       } else {
   14           console.log("2 - else");
   15       }
   16       if(false) {
   17           console.log("3 - if");
   18       } else if (false) {
   19           console.log("3 - else if");
   20       } else {
   21           console.log("3 - else");
   22       }
   23  </script>

关于【代码4-3】的分析如下:

这段代码主要使用了三段if…else if…else…语句块,分别用于演示if语句块、else if语句块和else语句块这三种不同的条件输出。

第02~08行代码是第一个if…else if…else…语句块,主要是通过if语句判断“true”是否为真,如果为“真”则执行if语句块中的第03行的代码并在控制台中输出调试信息,否则执行后面的语句;

第09~15行代码是第二个if…else if…else…语句块,主要是通过if语句判断“false”是否为真,如果不为“真”则继续通过else if语句判断“true”是否为真,如果为“真”则执行else if语句块中的第12行代码并在控制台输出调试信息,否则执行后面的语句;

第16~22行代码是第三个if…else if…else…语句块,主要是通过if语句判断“false”是否为真,如果不为“真”则继续通过else if语句判断“false”是否为真,如果不为“真”则执行else语句块中第21行的代码并在控制台输出调试信息。

页面效果如图4.3所示。对于if…else if…else…条件选择语句,运行中只能执行if语句块、else if语句块或else语句块中的内容,不可能全部都执行,不过也不可能都不执行,至少要执行一个语句块,这也同样是if…else if…else…条件选择语句的特点。

图4.3 if…else if…else…语句

提示

else if语句块可以扩展为多项并列的形式,这样就可以适用于绝大多数的编程场景。当然,如果并列项太多可以使用下面我们将要介绍到的switch条件选择语句。