流程控制语句

  • 条件判断语句 if
  • 条件分支语句 switch
  • 循环语句 for 、while

switch 和 if 都可以相互转换,switch 的性能更优于 if


1. 条件判断语句 if

在某条语句之前,使用条件判断语句。

如果条件成立才会执行 if 代码块 里的语句,不成立,则跳过 if 代码块 里的语句,而执行下面的语句。

if 语句,只会有一个代码块被执行。。。有一个代码块被执行了,if 语句就结束了。

  • 语法一

    • if(条件表达式1 && 条件表达式2)
      {
      语句1;
      语句2;
      }
  • 语法二
    • if(条件表达式1 && 条件表达式2)
      {
      语句1;
      语句2;
      }
      else
      {
      语句3;
      语句4;
      }
  • 语法三
    • if (条件表达式1 && 条件表达式2)
      {
      语句1;
      语句2;
      }
      else if (条件表达式3 && 条件表达式4)
      {
      语句3;
      语句4;
      }
      else
      {
      语句5;
      语句6;
      }

2. 条件分支语句

  • switch(条件表达式)
    {
    case 表达式1:
    语句1;
    语句2;
    break;
    case 表达式2:
    语句3;
    break;
    case 表达式3:
    语句4;
    语句5;
    语句6;
    break;
    default:
    语句7;
    break;
    }

    执行时,根据 条件表达式 的值与 case 的值依次进行全等比较,全等的则执行之后的除了 case 的所有语句。

如果遇到 break; 则马上跳出 switch 语句块。

如果所有的 case 都是 false,则执行 default 后面的语句。

  • switch 语句后面的表达式,与case语句后面的表示式比较运行结果时,采用的是严格相等运算符(===,而不是相等运算符(==),这意味着比较时不会发生类型转换。

    • var x = 1;
      
      switch (x) {
      case true:
      console.log('x 发生类型转换');
      break;
      default:
      console.log('x 没有发生类型转换');
      }
      // x 没有发生类型转换

3. 循环语句

  • while

    • while(条件表达式)
      {
      语句1;
      语句2;
      }
    • 先判断条件表达式,再执行一次代码块。每执行完一次代码块,就判断一次条件表达式。
    • 只要条件表达式成立,就会一直执行代码块。

  • do while

    • do
      {
      语句1;
      语句2;
      }
      while(条件表达式);
    • 先执行一次代码块,再进行条件表达式判断,如果成立,则再循环一次。
    • 只要条件表达式成立,就会一直执行代码块。
    • 这种循环至少会执行一次。
  • for

    • for(初始化表达式; 条件表达式; 递增表达式)
      {
      语句1;
      语句2;
      }
  • 初始化表达式(initialize):确定循环变量的初始值,只在循环开始时执行一次。
  • 条件表达式(test):每轮循环开始时,都要执行这个条件表达式,只有值为真,才继续进行循环。
  • 递增表达式(increment):每轮循环的最后一个操作,通常用来递增循环变量。

break; 和 continue;

  • 这两条语句用于在循环中精确控制代码的执行。
  • break; 用于立刻跳出最近的循环,强制从外面的代码开始执行。。。用在 循环 switch
  • continue; 用于立刻结束当次循环,去进行条件语句的判断,然后继续正常运行。。。只能用在循环中。

代码块

  • 程序,是由一条一条语句组成的。
  • 语句从上往下按顺序一条一条执行。
  • 在 js 中使用 {} 对语句进行分组,他们要么都执行,要么都不执行。。。
  • {语句1;语句2;} 这样的我们称其为 " 区块 "  或者 "代码块"。
  • 在代码块后面就不许要分号了。
  • 只具有语句分组的作用,单独使用无影响。

标签 label

  • javascript 允许语句前面有标签,相当于定位符, 用于跳转到程序的标签位置

    •  
  • break 标签
    • 跳出 标签的代码块

      • foo: {
        console.log(1);
        break foo;
        console.log('本行不会输出');
        }
        console.log(2);
      • 还可以跳出多层循环
      • top:
        for (var i = 0; i < 3; i++){
        for (var j = 0; j < 3; j++){
        if (i === 1 && j === 1) break top;
        console.log('i=' + i + ', j=' + j);
        }
        } // i=0, j=0
        // i=0, j=1
        // i=0, j=2
        // i=1, j=0
  • continue 标签
    • 满足条件时,会跳过当前循环,直接进入下一轮外层循环。
    • 如果continue语句后面不使用标签,则只能进入下一轮的内层循环。
      • top:
        for (var i = 0; i < 3; i++){
        for (var j = 0; j < 3; j++){
        if (i === 1 && j === 1) continue top;
        console.log('i=' + i + ', j=' + j);
        }
        }
        // i=0, j=0
        // i=0, j=1
        // i=0, j=2
        // i=1, j=0
        // i=2, j=0
        // i=2, j=1
        // i=2, j=2

(56)Wangdao.com第八天_JavaScript 流程控制语句的更多相关文章

  1. (55)Wangdao.com第八天_JavaScript 字符串中使用 \u 输出Unicode字符

    JavaScript中,使用Unicode 需要 \u 进行转义,格式 "\u十六进制" console.log(\u0031); console.log(\u0041); // ...

  2. Python流程控制语句

    人们常说人生就是一个不断做选择题的过程:有的人没得选,只有一条路能走:有的人好一点,可以二选一:有些能力好或者家境好的人,可以有更多的选择:还有一些人在人生的迷茫期会在原地打转,找不到方向.对于相信有 ...

  3. 【转】Python流程控制语句

    [转]Python流程控制语句 人们常说人生就是一个不断做选择题的过程:有的人没得选,只有一条路能走:有的人好一点,可以二选一:有些能力好或者家境好的人,可以有更多的选择:还有一些人在人生的迷茫期会在 ...

  4. 流程控制语句if基本概述

    目录 1. 流程控制语句if基本概述 2. 流程控制语句if文件比较 判断文件是否存在,返回方式 使用变量的方法进行判断 请输入你要备份的数据库名称: wordpress 请输入你要备份的数据库密码: ...

  5. Linux Shell 流程控制语句

    * 本文主要介绍一些Linux Shell 常用的流程控制语句* 1. if 条件语句:if-then/if-elif-fi/if- else-fi if [条件判断逻辑1];then command ...

  6. 8-04流程控制语句BEGIN ..END

     流程控制语句: 是用来控制程序流程的语句. 常用的流程控制语句的分类: 顺序结构:BEGIN...END 分支结构: IF ..ELSE 或CASE ..END 循环结构:WHILE 顺序结构 语法 ...

  7. JAVA 1.6 流程控制语句

    1. 条件运算符(三元表达式),其形式为:type d = a ? b : c; 具体化形式为:int d = 2 < 1 ? 3 : 4;2. 轻量级的文本编辑器:UltraEdit.Edit ...

  8. 20151013 C# 第一篇 流程控制语句

    20151013 流程控制语句: 1.选择语句 if … else if...else 选择语句 if(布尔表达式){  语句块:} if(布尔表达式){  语句块1:}else{  语句块2:} i ...

  9. java基础3_流程控制语句

    一 条件判断 1. 条件运算符(三元表达式) ,其形式为: type d = a ? b : c; 具体化形式为:int d = 2 < 1 ? 3 : 4; 2. 轻量级的文本编辑器:Ultr ...

随机推荐

  1. 金融量化分析【day113】:布林带策略

    一.布林带策略简介 1.简介 2.计算公式 3.图形      二.布林带策略代码 import jqdata def initialize(context): set_benchmark('0000 ...

  2. line-height与height

    line-height是行高,height就是高,通常height是对于某个框架或者图片来弄的,line-height用于文字 如果要实际效果你可以写一段文字,分好几行,然后对它做line-heigh ...

  3. FineUIMvc 常见问题及解决办法

    Ø  简介 FineUIMvc 是基于 jQuery 的专业 ASP.NET MVC/Core 控件库,本文主要介绍 FineUIMvc 的常见问题及解决办法. 1.   View 中无法调用 Htm ...

  4. LINQ to SQL 调用 SQL Server 的系统函数

    Ø  简介 在 C# 中比较常用的 ORM(Object Relational Mapping)框架就是 EF 了,EF 经常结合 LINQ to SQL 来操作数据库.本文主要讨论如何在 LINQ ...

  5. EffectiveC++ 第7章 模板与泛型编程

    我根据自己的理解,对原文的精华部分进行了提炼,并在一些难以理解的地方加上了自己的"可能比较准确"的「翻译」. Chapter 7 模版与泛型编程 Templates and Gen ...

  6. H5取经之路——随便写点儿

    [相对定位] * 1.使用position:relative:设置元素为相对定位的元素: * 2.定位机制: ①相对于自己原来文档流中的的位置定位,当不指定top等定位值时,不会改变元素位置: ②相对 ...

  7. mapState

    store.js import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) const store = new Vuex.Store({ ...

  8. Spring Cloud Context模块

    SpringCloud这个框架本身是建立在SpringBoot基础之上的,所以使用SpringCloud的方式与SpringBoot相仿.也是通过类似如下代码进行启动. SpringApplicati ...

  9. linux SWAP

    1.内存和SWAP之间合理的分配方案 M = Amount of RAM in GB, and S = Amount of swap in GB, then If M < 2, S = M *2 ...

  10. python3 基础语法(二)

    一.python3的基本数据类型: 和其他语言一样都包含了以下数据类型: 类型 含义 实例 INT 整型(integer) 1 FLOAT 浮点型 1.1 BOOL 布尔值 TRUE/FALSE ST ...