首页 > 其他分享 >JS中搜索数组的四种方法

JS中搜索数组的四种方法

时间:2022-10-29 10:02:37浏览次数:107  
标签:返回 indexOf JS 索引 数组 Array includes 四种

前端经常要通过javaScript来处理数组中的数据,其中就包括检查数组中是否包含满足特定搜索条件的单个或者多个值,这就需要我们关于用于确认的布尔值、数组中值得位置索引或包含所有搜索结果的单独数组等。

在ECMAScript6之前,最常用的方法就是通过for循环来遍历数组中的所有项目并对项目执行操作。现在我们可以通过内置的使用方法来完成在数组中搜索值的常见任务。

本文将介绍Array.includes()、Array.indexOf()、Array.fiind()和Array.filter这些方法。

使用includes()

根据数组中是否存在值,includes()方法将返回true或false

基本语法:

JS中搜索数组的四种方法_搜索

第一个参数valueToFind是数组中要匹配的值,第二个参数fromIndex是可选的,用于设置开始比较的索引,因为默认值为0,意味着默认搜索整个数组。

请看alligator facts的示例数组:

JS中搜索数组的四种方法_js_02

然后使用includes()检查数组中是否存在字符串”thick scales”

JS中搜索数组的四种方法_js_03

代码返回true,因为字符串存在于数组中。

如果你添加fromIndex参数以便于在”thick scales”之后进行比较,则将返回false

JS中搜索数组的四种方法_js_04

此外,还有一些需要注意的重要事项,这里的.includes()方法使用严格比较,例如:

JS中搜索数组的四种方法_搜索_05

上述代码返回true,因为数值80在数组中。

JS中搜索数组的四种方法_搜索_06

上述代码将返回false,因为字符串值'80'不在数组中。

includes()对于只需要知道值是否存在于数组肿的用例很有帮助

使用indexOf()

indexOf()方法返回数组中值的第一个索引,如果没有匹配项,则返回-1。

基本语法如下:

JS中搜索数组的四种方法_搜索_07

回顾alligator facts的示例数组:

JS中搜索数组的四种方法_字符串_08

使用indexOf()返回字符串"rounded snout"的第一个索引:

JS中搜索数组的四种方法_字符串_09

返回字符串"rounded snout"的索引—3

JS中搜索数组的四种方法_前端页面_10

上述代码返回-1,因为该字符串不在数组中。

JS中搜索数组的四种方法_搜索_11

以上代码返回1

JS中搜索数组的四种方法_搜索_12

返回4,因为在索引2之后找到该元素,为数组中第四个元素

注意:如果你查找的不是第一个结果,那么或许可以使用lastIndexOf(),lastIndexOf()方法与indexOf()类似,但将从数组的最后一个索引开始查找第一个匹配项并往回工作。

indexOf对于需要搜索结果的耽搁索引的用力很有帮助。

使用find()

find()方法返回数组中与函数条件匹配的第一个值,如果没有匹配项,则返回undefined

基本语法如下:

JS中搜索数组的四种方法_搜索_13

回顾alligator facts的示例数组:

JS中搜索数组的四种方法_数组_14

然后使用find()返回长度小于13个字符的第一个值:

JS中搜索数组的四种方法_前端页面_15

此示例仅使用callback参数。

80是一个数值。"rounded snout"的长度为13个字符,"thick scales"有12个字符,而"4 foot tail"有11个字符——这两者都满足函数条件,但是,find()只会返回第一个值,即返回"thick scales"。

以下为使用可选的index参数的示例:


JS中搜索数组的四种方法_搜索_16

"thick scales"、"4 foot tail"和"rounded snout"都满足第一个条件(typeof el === 'string')。如果这是唯一的条件,则返回第一个,即"thick scales"。但因为有第二个条件(idx === 2),所以最后代码返回"4 foot tail"。

注意:如果你查找的是索引而不是值,那么可能会倾向于使用findIndex()。findIndex()方法也接收函数,但它返回匹配元素的索引而不是元素本身。

find()对于需要单个搜索结果值的用例很有帮助。

使用filter()

filter()方法返回新数组,新数组包含所有与函数条件匹配的值。如果没有匹配项,则返回空数组。

基本语法如下:


JS中搜索数组的四种方法_js_17

还是alligator facts的示例数组:

JS中搜索数组的四种方法_前端页面_18

然后使用filter()返回所有等于80的值:

JS中搜索数组的四种方法_字符串_19

数组中的两个值80都满足条件。因此返回新数组:[80, 80]。

filter()对于需要多个搜索结果值的用例很有帮助。

总结

数组中的两个

本文重点介绍了Array.includes()、Array.indexOf()、Array.find()和Array.filter。每个都可以为用例需求提供解决方案。

只需要知道值是否存在?这时可以使用includes()。

需要获取元素本身?可以对单个项目使用find()或对多个项目使用filter()。

需要查找元素的索引?应该使用indexOf()搜索原语或使用findIndex()搜索函数。

以上是CRMEB分享的JS中搜索数组的四种方法的所有内容,感谢大家的阅读!

标签:返回,indexOf,JS,索引,数组,Array,includes,四种
From: https://blog.51cto.com/u_15723831/5805733

相关文章

  • 扁平数组转树结构
    <!DOCTYPEhtml><htmllang="en"> <head> <title></title> <metacharset="UTF-8"> <metaname="viewport"content="width=device-width,initial-scale=1"> <......
  • js promise概念
    Promise构造函数接受一个函数作为参数。该函数的两个参数分别是resolve和reject,它们是两个函数,由JavaScript引擎提供,不用自己部署。//代码resolve函数的作用:将Promi......
  • Node.js
    Node.js是一个基于ChromeV8引擎的JavaScript运行环境。一、初识Node.js环境的安装安装途径:官网:https://nodejs.org/en/LTS版本是长期稳定版,建议安装源码下......
  • 将1000内素数放入数组
    #include<stdio.h>intmain(){inti=0;intj=0;inttemp=0;intarr[1000]={};for(i=2;i<1000;i++){ for(j=2;j<i;j++){ if(i%j==0){ break;}} if(......
  • 【JS】类继承
    类继承:    -可以实现一个类扩展另一个类    -使用extends关键字进行类继承      classChildextendsParent        ......
  • 1879. 两个数组最小的异或值之和
    题目描述给了两个数组nums1和nums2,长度都是n,问怎么排列可以让数组对应元素的异或值之和最小?f1-二进制枚举+状态压缩基本分析1.有没有是啥贪心做法,因为看到相同元素异或......
  • 今天,念念不忘一件事... ✅FastJson在调用JSON#toJSONString时,如何截取比较长的value串
    项目里前后端页面的http请求及dubbo服务间的RPC调用,返回值类型统一是一个Result<T>,其结构如下。@DatapublicclassResult<T>implementsSerializable{priv......
  • JavaScript--JSONP和Axios
    JSONP概述:JSONP(JSONwithpadding)是一种跨域解决方案,它主要是利用了script标签不受跨域影响的特性来完成对应的请求操作。实际上是一个get请求。JSONP格式包含两个部分:......
  • JS中数值类型的本质
    一、JS中的数值类型众所JS爱好友周知,JS中只有一个总的数值类型——number,它包含了整型、浮点型等数值类型。其中,浮点数的实现思想有点复杂,它把一个数拆成两部分来存储。第......
  • PYTHON JSON EXCEL
    #+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++#pipinstallpandas#pipinstallopenpyxl#importjsonimporttimeimportpandasimpor......