js判断【数组】中是否包含某个元素的方法

1.indexOf方法

let arr = [2,3,4];

let res = arr.indexOf(2) // 验证是否包含:2
console.log(res) // 结果:0

let res2 = arr.indexOf(3) // 验证是否包含:3
console.log(res2) // 结果:1

let res3 = arr.indexOf(4) // 验证是否包含:4
console.log(res3) // 结果:2

let res4 = arr.indexOf(5) // 验证是否包含:5
console.log(res4) // 结果:-1

// 由此我们发现,indexOf 返回的是数组的下标,当没有包含时返回的是 -1
// 我们就可以通过这样的方式判断是否存在,判断结果是否大于 -1,大于则包含,不大于则不包含
let has = (arr.indexOf(5) > -1)
console.log(has) // 结果:false

2.find函数

let arr = [2,3,4];
// find函数会循环遍历,整个数组
arr.find(function(value,index,arr){
	console.log(value) // 结果:2 3 4
	console.log(index) // 结果:0 1 2
	console.log(arr) // 结果:[2, 3, 4]
})

let find = arr.find(function(value,index,arr){
  return value === 2
})
console.log(find) // 结果:2

let find2 = arr.find(function(value,index,arr){
  return value === 5
})
console.log(find2) // 结果:undefined

let find3 = arr.find(function(value, index, arr) {
return value > 2;
})
console.log(find3) // 结果:3

// 我们发现
// 当数组中的元素在测试条件时返回 true 时, find() 返回符合条件的元素,之后的值不会再调用执行函数。
// 如果没有符合条件的元素返回 undefined

3.findIndex函数

let arr = [2,3,4];

let findIndex = arr.findIndex(function(value,index,arr){
  console.log(value) // 结果:2 3 4
  console.log(index) // 结果:0 1 2
  console.log(arr) // 结果:[2, 3, 4]
})
console.log(findIndex) // 结果:-1

let findIndex1 = arr.findIndex(function(value){
  return value === 2
})
console.log(findIndex1) // 结果:0

let findIndex2 = arr.findIndex(function(value){
  return value === 3
})
console.log(findIndex2) // 结果:1

let findIndex4 = arr.findIndex(function(value){
  return value === 5
})
console.log(findIndex4) // 结果:-1

// 由此发现findIndex返回的 数组的index,不包含返回-1
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值