js判断是由含有a节点_如何在 JS 中判断数组是否包含指定的元素(多种方法)

作者:Abhilash Kakumanu

译者:前端小智

来源:medium

最近开源了一个 Vue 组件,还不够完善,欢迎大家来一起完善它,也希望大家能给个 star 支持一下,谢谢各位了。

简介

数组是我们编程中经常使用的的数据结构之一。在处理数组时,我们经常需要在数组中查找特定的值,JavaScript 包含一些内置方法来检查数组是否有特定的值或对象。

今天,我们来一起看看如何检查数组是否包含特定值或元素。

检查数组是否包含一个基本类型的值

Arrya.includes() 方法

检查数组值的最简单方法是使用include()方法,如下所示:

let animals = ["🐘", "🐒", "🐶", "🐍"]

animals.includes("🐶") // true

animals.includes("🐱") // false

该函数返回一个布尔值,表示该值是否存在。

Arrya.indexOf() 方法

在需要查找的元素的确切位置的情况下,可以使用indexOf(elem)方法,该方法在指定的数组中查找elem并返回其第一次出现的索引,如果数组不包含elem则返回-1。

例如,我们可以在包含 grade 的数组中查找第一次出现的 grade:

let grades = ["B", "D", "C", "A"]

grades.indexOf("A") // 3

grades.indexOf("F") // -1

在第一个实例中,元素出现,并返回其位置,在第二个实例中,返回值表示元素不存在。

我们可以使用它来轻松地改变代码流

let grades = ["B", "D", "C", "A"]

if (grades.indexOf("F") >= 0) {

console.log("元素存在");

} else {

console.log("元素不存在");

}

检查对象数组是否包含对象

some() 方法

在搜索对象时,include()检查提供的对象引用是否与数组中的对象引用匹配。这不是我们想要的,因为对象可以有相同的字段和相应的值,但引用不同。

我们可以使用some()方法根据对象的内容进行搜索。some()方法接受一个参数,接受一个回调函数,对数组中的每个值执行一次,直到找到一个满足回调函数设置的条件的元素,并返回true。

为了更好地理解它,让我们看看一些 some()的实际应用

let animals = [{name: "dog"}, {name: "snake"}, {name: "monkey"}, {name: "donkey"}]

let element = {name: "monkey"}

animals.some(animal => animal.name === element.name)

回调函数在前两种情况下返回 false,但在第三个情况下返回 true,因为名称匹配。 此后,some()暂停执行并返回 true。

总结

在本文中,我们介绍了在JavaScript中检查数组是否包含指定值的几种方法。

我们已经介绍了include()函数,它会在值存在时返回一个布尔值。函数的作用是:如果值存在,则返回该值的索引;如果不存在,则返回-1。

最后,对于对象,some()函数可帮助我们根据对象的内容搜索对象的存在。

我是小智,我要去刷碗了,我们下期再见!

代码部署后可能存在的BUG没法实时知道,事后为了解决这些BUG,花了大量的时间进行log 调试,这边顺便给大家推荐一个好用的BUG监控工具 Fundebug。

交流

文章每周持续更新,可以微信搜索「 大迁世界 」第一时间阅读和催更(比博客早一到两篇哟),本文 GitHub https://github.com/qq449245884/xiaozhi 已经收录,整理了很多我的文档,欢迎Star和完善,大家面试可以参照考点复习,另外关注公众号,后台回复福利,即可看到福利,你懂的。

1460000020353567?w=800&h=400

本文同步分享在 博客“前端小智”(SegmentFault)。

如有侵权,请联系 support@oschina.cn 删除。

本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值