JavaScript中如何终止forEach循环&跳出for(双层)循环?
在JavaScript中,
forEach
方法是用于遍历数组的,通常没有直接终止循环的机制。然而,我们可以使用一些技巧来模拟终止forEach
循环。以下是几种常见的方法
1.使用return
语句:在forEach
回调函数内部使用return
语句可以实现类似终止循环的效果。当需要终止循环时,可以在回调函数中返回false
或者任意其他特定值。
const arr = [1, 2, 3, 4, 5, 6, 7];
let terminate = false;
arr.forEach((element) => {
if (terminate) {
return;
}
console.log(element);
if (element === 3) {
terminate = true; // 终止循环
}
});
2.使用异常处理:通过抛出一个自定义的异常,可以终止forEach
循环。在捕获到该异常后,程序会跳出forEach
循环。
const arr = [1, 2, 3, 4, 5, 6, 7];
try {
arr.forEach((element) => {
console.log(element);
if (element === 3) {
throw 'TerminateException'; // 抛出自定义异常
}
});
} catch (e) {
if (e !== 'TerminateException') {
throw e; // 抛出其他异常
}
}
3.使用for...of
循环:如果只需要在特定条件下终止循环,可以考虑使用for...of
循环代替forEach
循环。for...of
循环支持break
语句来终止循环。
const arr = [1, 2, 3, 4, 5, 6, 7];
for (const item of arr) {
console.log(item);
if (item === 4) {
break; // 终止循环
}
}
4.将数组长度设置成0
const array = [ 1, 2, 3, 4, 5, 6, 7 ]
array.forEach((item) => {
if (item >= 4) {
console.log(item) // 输出:4
array.length = 0
}
})
5.建议使用for循环和some方法
const arr = [1, 2, 3, 4, 5, 6, 7]
for (let i = 0, len = arr.length; i < len; i++) {
if (arr[ i ] >= 4) {
console.log(arr[ i ]) // 4
break // return
}
}
6.双层for循环跳出循环
// 双层for循环跳出循环 =>
for (let index = 0; index < 10; index++) {
console.log('--------', '第一个循环');
let flag = false;
for (let ind = 0; ind < 10; ind++) {
console.log('--------', '第二个循环', index, ind);
if(index * ind > 20) {
console.log('--------', '跳出循环');
flag = true;
break;
}
}
if(flag) {
break
}
}
outer: for (let index = 0; index < 10; index++) {
console.log('--------', '第一个循环');
for (let ind = 0; ind < 10; ind++) {
console.log('--------', '第二个循环', index, ind);
if(index * ind > 20) {
console.log('--------', '跳出循环');
break outer; // 这个是跳出整个循环
// return 这个是终止循环
}
}
}
感谢大大关注!!!
JavaScript中如何终止forEach循环&跳出for(双层)循环?的更多相关文章
- JavaScript中如何中断forEach循环
先来看下forEach的实现 // Production steps of ECMA-262, Edition 5, 15.4.4.18// Reference: http://es5.github. ...
- JavaScript中Map和ForEach的区别
译者按: 惯用Haskell的我更爱map. 原文: JavaScript — Map vs. ForEach - What’s the difference between Map and ForE ...
- JavaScript 中 map、foreach、reduce 间的区别
一直对map.foreach.reduce这些函数很是生疏,今天看underscorejs时好好研究了一下,一研究我就更懵了,这不是一样嘛,都是遍历,所以我就去知乎找了一下,整理出了比较好的几个说法. ...
- 浅谈JavaScript中的Function引用类型
引言 在JavaScript中最有意思的就是函数了,这一切的根源在于函数实际上是一个对象.每一个函数都是Function类型的实例,而且都和其他引用类型的实例一样具有属性和方法.函数作为一个对象,因此 ...
- 理解 JavaScript 中的 for…of 循环
什么是 for…of 循环 for...of 语句创建一个循环来迭代可迭代的对象.在 ES6 中引入的 for...of 循环,以替代 for...in 和 forEach() ,并支持新的迭代协议. ...
- 深入了解 JavaScript 中的 for 循环
在ECMAScript5(简称 ES5)中,有三种 for 循环,分别是: 简单for循环 for-in forEach 在2015年6月份发布的ECMAScript6(简称 ES6)中,新增了一种循 ...
- Javascript中while和do-while循环用法详解
while循环 while 语句与 if 语句相似,都有条件来控制语句(或语句块)的执行,其语言结构基本相同:while(conditions){ statements;} while 语句与 ...
- 深入了解JavaScript中的for循环
在ECMAScript5中,有三种for循环,分别是: 简单for循环 for-in forEach 在ES6中,新增了一种循环 for-of 简单for循环 const arr = [1, 2, 3 ...
- Javascript/Jquery 中each() 和forEach()的区别
从名字看上去这两个方法好像有点关系,但在javascript中它们区别还是挺大的. forEach() 用于数组的操作,对数组中的每个元素执行制定的函数(不是数组不能使用forEach()方法). 而 ...
- JavaScript中的for in循环
在学习AJAX的时候,发现JavaScript中for in循环,这种循环对于遍历JSON是很好用的.于是写下了这篇博文 作用 for in循环本质上是forEach循环,它主要有两个作用 遍历数组 ...
随机推荐
- dotnet OpenXML 读取 PPT 主序列进入退出强调动画
本文告诉大家如何读取 PPT 文件里面,放在主动画序列 MainSequence 的进入和退出和强调的动画,和在 OpenXML 里面的存放方式 如以下的课件内容,给一个元素添加了进入强调退出的动画, ...
- 如何在 Linux 上部署 RabbitMQ
如何在 Linux 上部署 RabbitMQ 目录 如何在 Linux 上部署 RabbitMQ 安装 Erlang 从预构建的二进制包安装 从源代码编译 Erlang RabbitMQ 的安装 使用 ...
- 通过Google浏览器Cookie文件获取cookie信息,80以上版本有效
public class ReadCookie { /// <summary> /// </summary> /// <param name="hostName ...
- async 与 promise 的区别
async函数会引式返回一个promise,而promise的resolve值就是函数return的值 使用async和await明显节约了不少代码,不需要.then,不需要写匿名函数处理promis ...
- Competition Set - AtCoder I
这里记录的是这个账号的比赛情况. ARC172 2024-2-18 Solved:4/6 D(Hard-,2936) 给定所有数对 \((i,j),1\le i\lt j\le n\) 的一个排列 \ ...
- 三、Prophecis 一站式云原生机器学习平台
Prophecis 是微众银行自研大数据平台套件 WeDataSphere 的核心应用工具之一,为用户提供了全栈的机器学习应用开发与部署解决方案.作为WeDataSphere 功能工具应用系统,Pro ...
- kali linux 渗透测试 01 kali介绍
安全问题的根源 分层思想------盲人摸象 只追求功能实现----比较片面 最大的安全威胁是人---- 安全目标 先于攻击者发现和防止漏洞出现 攻击型安全 防护性安全 渗透测试 尝试击破安全防御机制 ...
- 命令行创建vue项目
vue -h vue create learn-vue ❯ Manually select features 选择下面的组件(空格为选中/取消)回车确认 使用 history mode 使用node ...
- LVS负载均衡(3)-- DR模型搭建实例
目录 1. LVS DR模型搭建 1.1 DR模型网络规划 1.2 RS设备的VIP冲突解决方式 1.3 DR模型访问流程 1.4 DR模型配置 1.4.1 ROUTER设备配置 1.4.2 后端ng ...
- RMBG1.4服务器部署指南
近期,一家AIGC公司BRIA开源了一个出圈的模型:RMBG-1.4,它可以实现高质量地一键去除图片中的背景.下面是一些具体的例子,可以看到这个模型可以实现非常精细的"抠图". R ...