js数组循环常用的几种方法

前端开发中,经常要用到循环,保存一份,后面慢慢补充。

js数组循环常用的几种方法:。

1、for循环

最基本的循环方式,也是速度比较快,效率比较高的循环方式,

javascript 复制代码
var arr = [1,2,3,4,5];
for (var i = 0; i < arr.length; i++) {
	console.log(arr[i]);
}

2、forEach循环

历数组中的每一项,没有返回值,对原数组没有影响,不支持IE,break无法跳出循环,retrun只能跳出当前循环,无法终止循环。

javascript 复制代码
var arr = [1,2,3,4,5];
arr.forEach(function (item, index, array) {
	// item数组中的当前项, index当前项的索引, array原始数组;
	console.log(item);
})

3、map循环

有返回值,支持return返回值,把每一次循环return返回的值组成一个新的数组,对原数组没有影响。

javascript 复制代码
var arr = [1,2,3,4,5];
var newArr = arr.map(function (item, index, array) {
	return item * 10;
})
console.log(arr); // [1,2,3,4,5]
console.log(newArr); // [10,20,30,40,50]

4、for of循环

ES6新增的循环方法,没有索引,它可以正确响应break、continue和return语句,而且,这个方法避开了for-in循环的所有缺陷。for-in循环虽然可以循环数组,但是会有好多坑,它主要用于循环对象,今天我总结的是数组的循环,就把for-in排除在外了。

javascript 复制代码
var arr = [1,2,3,4,5];
for (var item of arr) {
	// item指的的就是数组每一项的值
	console.log(item);
}

5、filter循环

返回新数组,不会改变原数组,新数组由符合条件的数组组成。

javascript 复制代码
var arr = [1,2,3,4,5];
var newArr = arr.filter(function (item) {
	return item > 3;
})
console.log(arr); // [1,2,3,4,5]
console.log(newArr); // [4,5]

6、every循环

给数组每一项都运行一个函数,如果每一项都符合条件,就返回true,否则返回false。

javascript 复制代码
var arr = [1,2,3,4,5];
var result1 = arr.every(function (item, index, array) {
	return item > 3;
});
var result2 = arr.every(function (item, index, array) {
	return item > 0;
})
console.log(result1); // false
console.log(result2); // true

7、some循环

给数组每一项都运行一个函数,同every相反,只要有一项符合条件,就跳出循环,返回true,否则返回false。

javascript 复制代码
var arr = [1,2,3,4,5];
var result1 = arr.some(function (item, index, array) {
	return item > 4;
});
var result2 = arr.some(function (item, index, array) {
	return item > 5;
})
console.log(result1); // true
console.log(result2); // false

8、find循环

给数组每一项都运行一个函数,只要有一项符合条件,就跳出循环,返回第一个符合条件的元素,否则返回undefined。

javascript 复制代码
var arr = [1,2,3,4,5];
var result1 = arr.find(function (item) {
	return item > 3;
});
console.log(result1); // 4

还有其他的方法,欢迎大家补充。

相关推荐
酷爱码30 分钟前
如何通过python连接hive,并对里面的表进行增删改查操作
开发语言·hive·python
画个大饼32 分钟前
Go语言实战:快速搭建完整的用户认证系统
开发语言·后端·golang
喵先生!2 小时前
C++中的vector和list的区别与适用场景
开发语言·c++
Thomas_YXQ2 小时前
Unity3D Lua集成技术指南
java·开发语言·驱动开发·junit·全文检索·lua·unity3d
xMathematics3 小时前
计算机图形学实践:结合Qt和OpenGL实现绘制彩色三角形
开发语言·c++·qt·计算机图形学·cmake·opengl
Freedom风间4 小时前
前端优秀编码技巧
前端·javascript·代码规范
萌萌哒草头将军4 小时前
🚀🚀🚀 Openapi:全栈开发神器,0代码写后端!
前端·javascript·next.js
萌萌哒草头将军4 小时前
🚀🚀🚀 Prisma 爱之初体验:一款非常棒的 ORM 工具库
前端·javascript·orm
拉不动的猪5 小时前
SDK与API简单对比
前端·javascript·面试
runnerdancer5 小时前
微信小程序蓝牙通信开发之分包传输通信协议开发
前端