在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
有的时候,我们可能需要多次执行同一块代码。一般情况下,语句是按顺序执行的:函数中的第一个语句先执行,接着是第二个语句,依此类推。 编程语言提供了更为复杂执行路径的多种控制结构。 循环语句允许我们多次执行一个语句或语句组,下面是大多数编程语言中循环语句的流程图: 一、for 循环TypeScript for 循环用于多次执行一个语句序列,简化管理循环变量的代码。 语法语法格式如下所示: for ( init; condition; increment ){ statement(s); } 下面是 for 循环的控制流程解析:
在这里,statement(s) 可以是一个单独的语句,也可以是几个语句组成的代码块。 condition 可以是任意的表达式,当条件为 true 时执行循环,当条件为 false 时,退出循环。 流程图实例以下实例计算 5 的阶乘, for 循环生成从 5 到 1 的数字,并计算每次循环数字的乘积。 var num:number = 5; var i:number; var factorial = 1; for(i = num;i>=1;i--) { factorial *= i; } console.log(factorial) 编译以上代码得到如下 JavaScript 代码: var num = 5; var i; var factorial = 1; for (i = num; i >= 1; i--) { factorial *= i; } console.log(factorial); 执行以上 JavaScript 代码,输出结果为: 120 二、for...in 循环for...in 语句用于一组值的集合或列表进行迭代输出。 语法语法格式如下所示: for (var val in list) { //语句 } val 需要为 string 或 any 类型。 实例var j:any; var n:any = "a b c" for(j in n) { console.log(n[j]) } 编译以上代码得到如下 JavaScript 代码: var num = 5; var j; var n = "a b c"; for (j in n) { console.log(n[j]); } 执行以上 JavaScript 代码,输出结果为:
三、for…of 、forEach、every 和 some 循环此外,TypeScript 还支持 for…of 、forEach、every 和 some 循环。 1、for...of 语句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 } 2、forEach、every 和 someforEach、every 和 some 是 JavaScript 的循环语法,TypeScript 作为 JavaScript 的语法超集,当然默认也是支持的。 因为 forEach 在 iteration 中是无法返回的,所以可以使用 every 和 some 来取代 forEach。
TypeScript forEach 循环 let list = [4, 5, 6]; list.forEach((val, idx, array) => { // val: 当前值 // idx:当前index // array: Array }); TypeScript every 循环 let list = [4, 5, 6]; list.every((val, idx, array) => { // val: 当前值 // idx:当前index // array: Array return true; // Continues // Return false will quit the iteration }); 四、while 循环while 语句在给定条件为 true 时,重复执行语句或语句组。循环主体执行之前会先测试条件。 语法语法格式如下所示: while(condition) { statement(s); } 在这里,statement(s) 可以是一个单独的语句,也可以是几个语句组成的代码块。 condition 可以是任意的表达式,当条件为 true 时执行循环。 当条件为 false 时,程序流将退出循环。 流程图图表中,while 循环的关键点是循环可能一次都不会执行。当条件为 false 时,会跳过循环主体,直接执行紧接着 while 循环的下一条语句。 实例var num:number = 5; var factorial:number = 1; while(num >=1) { factorial = factorial * num; num--; } console.log("5 的阶乘为:"+factorial); 编译以上代码得到如下 JavaScript 代码: var num = 5; var factorial = 1; while (num >= 1) { factorial = factorial * num; num--; } console.log("5 的阶乘为:" + factorial); 执行以上 JavaScript 代码,输出结果为: 5 的阶乘为:120 五、do...while 循环不像 for 和 while 循环,它们是在循环头部测试循环条件。do...while 循环是在循环的尾部检查它的条件。 语法语法格式如下所示: do { statement(s); }while( condition ); 请注意,条件表达式出现在循环的尾部,所以循环中的 statement(s) 会在条件被测试之前至少执行一次。 如果条件为 true,控制流会跳转回上面的 do,然后重新执行循环中的 statement(s)。这个过程会不断重复,直到给定条件变为 false 为止。 流程图实例var n:number = 10; do { console.log(n); n--; } while(n>=0); 编译以上代码得到如下 JavaScript 代码: var num = 5; var n = 10; do { console.log(n); n--; } while (n >= 0); 执行以上 JavaScript 代码,输出结果为: 10 9 8 7 6 5 4 3 2 1 0 六、break 语句break 语句有以下两种用法:
如果您使用的是嵌套循环(即一个循环内嵌套另一个循环),break 语句会停止执行最内层的循环,然后开始执行该块之后的下一行代码。 语法语法格式如下所示: break; 流程图实例var i:number = 1 while(i<=10) { if (i % 5 == 0) { console.log ("在 1~10 之间第一个被 5 整除的数为 : "+i) break // 找到一个后退出循环 } i++ } // 输出 5 然后程序执行结束 编译以上代码得到如下 JavaScript 代码: var i = 1; while (i <= 10) { if (i % 5 == 0) { console.log("在 1~10 之间第一个被 5 整除的数为 : " + i); break; // 找到一个后退出循环 } i++; } // 输出 5 然后程序执行结束 执行以上 JavaScript 代码,输出结果为: 在 1~10 之间第一个被 5 整除的数为 : 5 七、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个偶数 编译以上代码得到如下 JavaScript 代码: var num = 0; var count = 0; for (num = 0; num <= 20; num++) { if (num % 2 == 0) { continue; } count++; } console.log("0 ~20 之间的奇数个数为: " + count); //输出 10 执行以上 JavaScript 代码,输出结果为: 0 ~20 之间的奇数个数为: 10 八、无限循环无限循环就是一直在运行不会停止的循环。 for 和 while 循环都可以创建无限循环。 for 创建无限循环语法格式: for(;;) { // 语句 } 实例 for(;;) { console.log("这段代码会不停的执行") } while 创建无限循环语法格式: while(true) { // 语句 } 实例 while(true) { console.log("这段代码会不停的执行") } |
请发表评论