TypeScript(六) 循环语句

1. TypeScript循环语句

1.1. 简述

  有的时候,我们可能需要多次执行同一块代码。一般情况下,语句是按顺序执行的:函数中的第一个语句先执行,接着是第二个语句,依此类推。
  循环语句允许我们多次执行一个语句或语句组。

1.2. for循环

  for循环用于多次执行一个语句序列,简化管理循环变量的代码。
语法:

for (init; condition; increment) {
    // 循环执行代码块
}

参数说明:
(1)init会首先执行,且只会执行一次,这一步允许您声明并初始化任何循环控制变量。
(2)之后,会判断condition。如果是true,则执行循环主体。如果是false,则不执行循环主体。且控制流会跳转到紧接着for循环下一条语句。
(3)在执行完for循环主体后,控制流会跳回上面的increment语句。该语句允许您更新循环控制变量。该语句可以留空,只要在条件后有一个分号出现即可。
(4)条件再次被判断,如果为true,则执行循环,这个过程是不断重复的。一直到条件变为false时,for循环终止。
实例:

for (init; condition; increment) {
    // 循环执行代码块
}
var num:number = 5; 
var i:number; 
var factorial = 1; 
for(i = num;i>=1;i--) {
   factorial *= i;
}
console.log(factorial)

执行结果:120

1.3. for…in循环

  For…in语句用于一组值的集合或者列表进行迭代输出。
语法:

for (var val in list) {
    // 语句
}

  val需要为string或any类型
实例

    var j;
    var n:any = "a b c";
    for ( j in n) {
        console.log(n[j]);
    }

执行结果:
在这里插入图片描述

1.4. for…of 、forEach、every 和 some 循环

  for…of 语句创建一个循环来迭代可迭代的对象。在 ES6 中引入的 for…of 循环,以替代 for…in 和 forEach() ,并支持新的迭代协议。for…of 允许你遍历 Arrays(数组), Strings(字符串), Maps(映射), Sets(集合)等可迭代的数据结构等。
实例:

let someArray = [1, "string", false];
for (let entry of someArray) {
    console.log(entry); // 1, "string", false
}

  forEach、every 和 some 是 JavaScript 的循环语法,TypeScript 作为 JavaScript 的语法超集,当然默认也是支持的。
  因为 forEach 在 iteration 中是无法返回的,所以可以使用 every 和 some 来取代 forEach。
实例:

let list = [4, 5, 6];
list.forEach((val, idx, array) => {
    // val: 当前值
    // idx:当前index
    // array: Array
});

1.5. while循环

  while语句在给定条件为true时,重复执行语句或者语句组。循环主体执行之前会先测试条件。
语法:

while(condition) {
   statement(s);
}

实例:

    var num: number = 5;
    var factorial: number = 1;
    while (num >= 1) {
      factorial = factorial * num;
      num--;
    }
    console.log("5 的阶乘为:" + factorial);

执行结果:
在这里插入图片描述

1.6. do…while循环

  它不像for和while循环,它们是在循环头部测试循环条件。do…while循环是在循环的尾部检查它的条件。
语法:

do {
   statement(s);
} while ( condition );

  注意:条件表达式出现在循环的尾部,所以循环中的 statement(s) 会在条件被测试之前至少执行一次。
   如果条件为 true,控制流会跳转回上面的 do,然后重新执行循环中的 statement(s)。这个过程会不断重复,直到给定条件变为 false 为止。
实例:

var num:number = 5;
    var n = 10;
    do {
        console.log(n);
        n--;
    } while (n >= 0);;

执行结果
在这里插入图片描述

1.7.break语句

  break语句有以下两种:
  当break语句出现在一个循环内时,循环会立即终止,且程序流将继续执行紧接着循环的下一条语句
  它可用于终止switch语句中的一个case
语法:

break;

实例:

 var i :number= 1;
    while (i <= 10) {
        if (i % 5 == 0) {
            console.log("在 1~10 之间第一个被 5 整除的数为 : " + i);
            break; // 找到一个后退出循环
        }
        i++;
    } // 输出 5 然后程序执行结束;

执行结果:
在这里插入图片描述

1.8. continue语句

  continue语句有点像break语句。但是它不强制终止,continue会跳过当前循环中的代码,强迫开始下一次循环。
  对于 for 循环,continue 语句执行后自增语句仍然会执行。对于 while 和 do…while 循环,continue 语句是重新执行条件判断语句。
语法:

continue;

实例:

 var num:number = 0;
    var count:number = 0;
    for (num = 0; num <= 20; num++) {
        if (num % 2 == 0) {
            continue;
        }
        count++;
    }
    console.log("0 ~20 之间的奇数个数为: " + count); //输出 10

执行结果:
在这里插入图片描述

1.9. 无限循环

  无限循环就是一直在运行不会停止的循环。 for 和 while 循环都可以创建无限循环。
语法:

for(;;) { 
   // 语句
}

实例:

for(;;) { 
   console.log("这段代码会不停的执行") 
}
while(true) { 
   // 语句
} 
  • 23
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值