ES6 find()、findIndex()与filter()数组新增方法详解


prtyaa
prtyaa 2023-12-26 17:05:00 67123
分类专栏: 资讯

前言

这篇文章就是来总结一下es6新增的几个常用的数组方法

find()

查找第一个符合条件的数组元素

找到一个符合条件的数组成员,返回该成员的值,如果没有找到,返回undefined
它的参数是一个回调函数。在回调函数中可以写你要查找元素的条件,当条件成立为true时,返回该元素。如果没有符合条件的元素,返回值为undefined。

以下代码在Arr数组中查找元素值大于2的元素,找到后立即返回。返回的结果为查找到的元素:

const Arr=[1,2,3];
var num=Arr.find(function(value){
	return value > 2
});
console.log(num);// 3

没有查找到符合元素,返回undefined:

const Arr=[1,2,3,];
var num=Arr.find(function(value){
	return value>10
});
console.log(num);// undefined

回调函数有三个参数。

value:当前的数组元素。
index:当前索引值。
arr: 被查找的数组。
const Arr=[1,2,3];
var num=Arr.find(function(val,index,arr){
	return index > 1 //下标大于1
});
console.log(num);// 3

findIndex()

查找数组内元素,找到第一个符合条件的数组成员,返回该成员的下标(index), 没找到返回-1

var arr = ["张三", "李四", "王五"];
var result1 = arr.findIndex(function(val, index, arr) {
	return val == "李四"; // 查找到的字符串"wang"下标为:1
})
console.log(result1); // 1
var result2 = arr.findIndex(function(val, index, arr) {
	return val == "李"; // 查找到的字符串"李",没有查到返回 -1
})
console.log(result2); // -1

filter()

filter()与find()使用方法也相同。同样都接收三个参数。不同的地方在于返回值。

filter()返回的是数组,数组内是所有满足条件的元素,而find()只返回第一个满足条件的元素。
如果条件不满足,filter()返回的是一个空数组,而find()返回的是undefined
var userArr = [
	{
		id: 1,
		userName: "张三"
	},
	{
		id: 2,
		userName: "李四"
	},
	{
		id: 3,
		userName: "王五"
	}
]
var demo = userArr.filter(function(item){
	return item.id >1
})
console.log(demo);

filter()方法也可以用于数组去重

let arr = [1, 2, 2, 3, 3, 3, 4, 5];
let newArr = arr.filter((value, index, array) => array.indexOf(value) === index);
console.log(newArr);// [ 1, 2, 3, 4, 5 ]

网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。

本文链接:https://www.xckfsq.com/news/show.html?id=30893
赞同 0
评论 0 条
prtyaaL0
粉丝 1 发表 2554 + 关注 私信
上周热门
银河麒麟添加网络打印机时,出现“client-error-not-possible”错误提示  1448
银河麒麟打印带有图像的文档时出错  1365
银河麒麟添加打印机时,出现“server-error-internal-error”  1151
统信桌面专业版【如何查询系统安装时间】  1073
统信操作系统各版本介绍  1070
统信桌面专业版【全盘安装UOS系统】介绍  1028
麒麟系统也能完整体验微信啦!  984
统信【启动盘制作工具】使用介绍  627
统信桌面专业版【一个U盘做多个系统启动盘】的方法  575
信刻全自动档案蓝光光盘检测一体机  484
本周热议
我的信创开放社区兼职赚钱历程 40
今天你签到了吗? 27
信创开放社区邀请他人注册的具体步骤如下 15
如何玩转信创开放社区—从小白进阶到专家 15
方德桌面操作系统 14
我有15积分有什么用? 13
用抖音玩法闯信创开放社区——用平台宣传企业产品服务 13
如何让你先人一步获得悬赏问题信息?(创作者必看) 12
2024中国信创产业发展大会暨中国信息科技创新与应用博览会 9
中央国家机关政府采购中心:应当将CPU、操作系统符合安全可靠测评要求纳入采购需求 8

添加我为好友,拉您入交流群!

请使用微信扫一扫!