js判断数组中是否包含某个指定元素的个数_js 数组包含某个元素

js判断数组中是否包含某个指定元素的个数_js 数组包含某个元素JavaScript判断数组中是否包含某个指定元素

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

方法一:arr.indexOf(某元素):未找到则返回 -1。
 if(arr.indexOf(某元素) > -1){ 
   //则包含该元素}

例:

 var fruits = ["Banana", "Orange", "Apple", "Mango"];
 var a = fruits.indexOf("Apple");  // 2
 //以上输出结果意味着 "Apple" 元素位于数组中下标为 2 的位置。

indexOf()完整语法:
 array.indexOf(item,start)

 //参数:  item:必须。查找的元素。  start:可选的整数参数。规定在字符串中开始检索的位置。  它的合法取值是 0 到 stringObject.length - 1。  如省略该参数,则将从字符串的首字符开始检索。
例:

 var fruits=["Banana","Orange","Apple","Mango","Banana","Orange","Apple"];
 var a = fruits.indexOf("Apple",4);  // 6

注:string.indexOf()返回某个指定的字符串值在字符串中首次出现的位置。

  1. 该方法将从头到尾地检索字符串 stringObject,看它是否含有子串 searchvalue。开始检索的位置在字符串的 fromindex 处或字符串的开头(没有指定 fromindex 时)。如果找到一个 searchvalue,则返回 searchvalue 的第一次出现的位置。
  2. stringObject 中的字符位置是从 0 开始的。
  3. 查找字符串最后出现的位置,使用 lastIndexOf() 方法。
方法二:arr.find()

数组实例的find()用于找出第一个符合条件的数组元素。它的参数是一个回调函数,所有数组元素依次遍历该回调函数,直到找出第一个返回值为true的元素,然后返回该元素,否则返回undefined。
find() 方法为数组中的每个元素都调用一次函数执行:

  • 当数组中的元素在测试条件时返回 true 时, find() 返回符合条件的元素,之后的值不会再调用执行函数。
  • 如果没有符合条件的元素返回 undefined
  • 注意: find() 对于空数组,函数是不会执行的。
  • 注意: find() 并没有改变数组的原始值。
 [1, 5, 10, 15].find(function(value, index, arr) { 
   
     return value > 9;
 }) // 10
 /** *使用方法 */
 arr.find(function(value) { 
   
     if(value === 要查找的值) { 
   
         //则包含该元素
     }
 })
方法三:array.findIndex()

array.findIndex()和array.find()十分类似,返回第一个符合条件的数组元素的位置,如果所有元素都不符合条件,则返回-1。
findIndex() 方法为数组中的每个元素都调用一次函数执行:
当数组中的元素在测试条件时返回 true 时, findIndex() 返回符合条件的元素的索引位置,之后的值不会再调用执行函数。如果没有符合条件的元素返回 -1注意: findIndex() 对于空数组,函数是不会执行的。
注意: findIndex() 并没有改变数组的原始值

[1,5,10,15].findIndex(function(value, index, arr) { 
   
     return value > 9;
 }) // 2

说明:
 方法二和方法三,这两个方法都可以发现NaN,弥补了方法一IndexOf()的不足。

 [NaN].indexOf(NaN) 
 // -1
 
 [NaN].findIndex(y => Object.is(NaN, y))
 // 0
方法四:for()

遍历数组,然后 if 判断

 var arr = [1, 5, 10, 15];
 //传统for
 for(let i=0; i<arr.length; i++) { 
   
     if(arr[i] === 查找值) { 
   
         //则包含该元素
     }
 }
 // for...of
 for(v of arr) { 
   
     if(v === 查找值) { 
   
         //则包含该元素
     }
 }
 //forEach
 arr.forEach(v=>{ 
   
     if(v === 查找值) { 
   
         //则包含该元素
     }
 })
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/180517.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 蓝墨云班课资源下载不了_蓝墨云班课老师怎么用

    蓝墨云班课资源下载不了_蓝墨云班课老师怎么用看见有人详细讲解了下载文件的原理,在这里我就不赘述了,直接上写好的代码。可能乱了点。有一点要提前说一下,做这个的时候,我想着只下载没有获得经验的文件。已经获得过经验的文件因为我用不到,所以就不用下,当然,改一下代码的话没货的经验的也能下。相关的代码在download_sours函数里面,jy表示的是经验,jy=N代表没获得经验的文件,改一下就行,去掉这个判断条件就能下载已经获得经验的资源了。最后,封装好的软件下载链接在文章最末尾importosimportreimporttimeimpor

    2025年6月25日
    4
  • GridView控件

    GridView控件

    2021年11月28日
    37
  • Mac 开启apache PHP

    Mac 开启apache PHP命令行:开启apache服务:sudoapachectlstart停止apache服务:sudoapachectlstop重启服务:sudoapachectlrestart查看版本:httpd-v开启之后打开浏览器输入:localhost,看到Itworks!说明服务正常开启!命令行打开系统隐藏目录:open/etc/apache21.httpd

    2022年7月12日
    25
  • Makefile 语法入门

    Makefile 语法入门一、Makefile简介Makefile是一种常用于编译的脚本语言。它可以更好更方便的管理你的项目的代码编译,节约编译时间(没改动的文件不编译)。注意Makefile文件命令必须是Makefile或者makefile,并使用make命令编译。 二、1个规则1.语法规则目标…:依赖…命令1命令2…2.目标…

    2022年5月1日
    35
  • 大数据与云计算和物联网之间的关系是什么_大数据信息主要安全问题不包括

    大数据与云计算和物联网之间的关系是什么_大数据信息主要安全问题不包括大数据时代的到来,是全球知名咨询公司麦肯锡最早提出的,麦肯锡称:“数据,已经渗透到当今每一个行业和业务职能领域,成为重要的生产因素。人们对于海量数据的挖掘和运用,预示着新一波生产率增长和消费者盈余浪潮的到来。”《互联网进化论》一书中提出“互联网的未来功能和结构将于人类大脑高度相似,也将具备互联网虚拟感觉,虚拟运动,虚拟中枢,虚拟记忆神经系统”,并绘制…

    2022年9月29日
    6
  • 允许跨域访问_vue浏览器清空跳转记录

    允许跨域访问_vue浏览器清空跳转记录from http://www.cnblogs.com/fengyuqing/p/javascript_xmlhttp.html在非IE下,使用XMLHttpRequest不能跨域访问,除非要访问的网页设置为允许跨域访问。将网页设置为允许跨域访问的方法如下: JavaResponse.AddHeader(“Access-Control

    2022年10月1日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号