时间:2022-02-02 09:34:27 | 栏目:JavaScript代码 | 点击:次
语法:array.forEach(callback(currentvalue,index,arr) ,thisValue)
其中
callback为数组中每个元素执行的函数,该函数可接受1-3个参数:
thisValue表示执行回调函数callback()时的this指向。可选参数。当不写时,则默认是指向window全局
示例
var arr = [1, 3, 5, 13, 2]; var res = arr.forEach(function(item,index) { console.log(`数组第${index+1}个元素是${item}`); }) console.log(res);//forEach的返回值为undefined,
运行结果:
forEach是不能通过break或者return跳出循环的,一般跳出循环的方式为抛出异常:
try { let array = [1, 2, 3, 4] array.forEach((item, index) => { if (item === 3) { throw new Error('end')//报错,就跳出循环 } else { console.log(item) } }) } catch (e) { }
这种写法反而很麻烦。
1.使用every替代:
let array = [1, 2, 3, 4] array.every((item, index) => { if (item === 3) { return true } else { console.log(item) } })
2.自己写一个😁
//可跳出循环的数组遍历 Array.prototype.loop = function(cbk) { //判断当前数组是否为空 if (this?.length) { for (let i = 0; i < this.length; i++) { let stop = cbk(this[i], i, this) //判断是否停止循环 if (stop) { break } } } } let array = [1, 2, 3, 4] array.loop ((item, index) => { if (item === 3) { return true } else { console.log(item) } })