JavaScript常用数组元素搜索或过滤的四种方法详解

 更新时间:2022年08月31日 16:40:19   作者:JackieDYH  
这篇文章主要介绍了JavaScript常用数组元素搜索或过滤的四种方法,每种方式通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
  1. 获取满足特定条件的数组中的所有项目
  2. 要检查是否满足条件?
  3. 检查数组中是否有特定值?
  4. 在数组中找到指定值的索引?

filter   find  includes   indexOf

Array.filter()

在数组中查找满足特定条件的元素

let newArray = array.filter(callback);

  • newArray是返回的新数组
  • array 是我们要进行查找的数组本身
  • callback 是应用于数组每个元素的回调函数

如果数组中没有项目符合条件,则返回一个空数组。

例如,如果我们要获取大于10的数字数组中的所有项目,则可以执行以下操作:
const array = [10, 11, 3, 20, 5];
const greaterThanTen = array.filter(element => element > 10);
console.log(greaterThanTen) //[11, 20]

Array.find()

查找满足特定条件的第一个元素

let element = array.find(callback);

  • element -当前被遍历的元素(必填)
  • index -当前遍历的元素的索引/位置(可选)
  • array- 当前数组(可选)

但是请注意,如果数组中没有项目符合条件,则返回 undefined。

const array = [10, 11, 3, 20, 5];
const greaterThanTen = array.find(element => element > 10);
console.log(greaterThanTen)//11

Array.includes()

确定数组是否包含某个值,并在适当时返回 true 或 false

const includesValue = array.includes(valueToFind, fromIndex)

  • valueToFind 是要在数组中检查的值(必填)
  • fromIndex 是要开始从中搜索元素的数组中的索引或位置(可选)
检查20是否为数组中的元素之一,则可以执行以下操作:
const array = [10, 11, 3, 20, 5];
const includesTwenty = array.includes(20);
console.log(includesTwenty)//true
如果要检查数组是否在第一个元素之外的其他位置包含10个,可以执行如下操作:
const array = [10, 11, 3, 20, 5];
const includesTenTwice = array.includes(10, 1);
console.log(includesTenTwice)//false

Array.indexOf()

返回可以在数组中找到给定元素的第一个索引。如果数组中不存在该元素,则返回 -1

const indexOfElement = array.indexOf(element, fromIndex)

  • element 是要在数组中检查的元素(必填),并且
  • fromIndex 是要从数组中搜索元素的启始索引或位置(可选)

请务必注意,includes 和 indexOf 方法都使用严格的相等性('===')搜索数组。如果值的类型不同(例如4和'4'),它们将分别返回 false 和 -1

让我们找到数组中 3 的索引。
const array = [10, 11, 3, 20, 5];
const indexOfThree = array.indexOf(3);
console.log(indexOfThree)//2

结语

无需使用 for 循环即可搜索数组

  • 如果你想找到在符合特定条件的阵列中的所有项目,使用 filter。
  • 如果你想检查是否至少有一个项目符合特定的条件,请使用 find。
  • 如果你想检查一个数组包含一个特定的值,请使用 includes。
  • 如果要在数组中查找特定项目的索引,请使用indexOf 

到此这篇关于JavaScript常用数组元素搜索或过滤的四种方法的文章就介绍到这了,更多相关js搜索数组元素内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 基于javascript 显式转换与隐式转换(详解)

    基于javascript 显式转换与隐式转换(详解)

    下面小编就为大家分享一篇基于javascript 显式转换与隐式转换(详解),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-12-12
  • openlayers4实现点动态扩散

    openlayers4实现点动态扩散

    这篇文章主要为大家详细介绍了openlayers4实现的点动态扩散,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • JS实现网页上随滚动条滚动的层效果代码

    JS实现网页上随滚动条滚动的层效果代码

    这篇文章主要介绍了JS实现网页上随滚动条滚动的层效果代码,涉及JavaScript页面元素属性的获取、运算及设置等操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • 浅谈javascript中call()、apply()、bind()的用法

    浅谈javascript中call()、apply()、bind()的用法

    一直对Javascript中的apply/call/bind的用法很模糊,恰好看到了这篇文章。对三者之间的区别与联系算是有了比较清晰的认识。这里记录下来,分享给大家。
    2015-04-04
  • JavaScript调试之console.log调试的一个小技巧分享

    JavaScript调试之console.log调试的一个小技巧分享

    日常开发中经常会需要console来查看当前对象的值。当然用debugger会更全面的查看,但是总有只喜欢用console的,比如我。下面这篇文章主要给大家分享了关于JavaScript调试之console.log调试的一个小技巧,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-08-08
  • js中常见的6种继承方式总结

    js中常见的6种继承方式总结

    js中的继承与其说是对象的继承,但更像是让函数的功能和用法的复用,下面这篇文章主要给大家介绍了关于js中常见的6种继承方式,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-01-01
  • JS使用canvas绘制旋转风车动画

    JS使用canvas绘制旋转风车动画

    这篇文章主要为大家详细介绍了JS使用canvas绘制旋转风车动画,有加速减速启动停止功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • ES6中Set和Map数据结构的简单讲解

    ES6中Set和Map数据结构的简单讲解

    大家心里是否产生过这样的疑问,JS中既然已经有对象这种数据结构,我们为什么还要再单独去使用Set或者Map呢?下面这篇文章主要给大家介绍了关于ES6中Set和Map数据结构的相关资料,需要的朋友可以参考下
    2022-08-08
  • 浅谈JS之tagNaem和nodeName

    浅谈JS之tagNaem和nodeName

    下面小编就为大家带来一篇浅谈JS之tagNaem和nodeName。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • 使用weixin-java-tools完成微信授权登录、微信支付的示例

    使用weixin-java-tools完成微信授权登录、微信支付的示例

    这篇文章主要介绍了使用weixin-java-tools完成微信授权登录、微信支付的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09

最新评论